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ABSTRACT 


We discuss the design and implementation of FIRE, an 
Intelligent Computer-Aided Instructional (ICAI) tutering 
system. It tutors Fire Team Leaders on U.S. Naval ships in 
fire control, including dressing personnel, setting fire 
boundaries, extinguishing fires, performing gas tests, 
debriefing personnel, and recovering from personnel injuries 
and broken equipment. A computer game environment 
challenges the user with a random fire scenario at’ the 
user's experience level. Using a multi-level tree of expert 
recovery actions, Fire can correctly choose the next best 
recovery action in any random fire scenario. Every 
incorrect student answer causes a formulation of a 
hypothesis concerning the cause of the behavioral difference 
between the student and an expert. This hypothesis guides 
selection of one of six possible tutoring strategies. The 
user can also perform a text-book=-type lookup of correct 


action information. 


THESIS DISCLAIMER 


The reader is cautioned that computer programs developed 
in this research may not have been exercised for all cases 
of interest. While every effort has been made, within the 
time available, to ensure that the programs are free of 
computational and logic errors, they cannot. be considered 
validated. Any application of these programs without 


additional verification is at the risk of the user. 
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The implementation of an effective damage control 
organization on US Naval Ships is the ultimate weapon to 
ensure the ship's survivability. Through realistic training 
for shipboard fire fighting groups, and using equipment that 
is maintained in an efficient operating condition, fire 
teams are able to successfully fight the most dangerous 
fires, thereby removing one of the greatest threats to the 
ship's offensive power [Ref. 1: p. E8]. Realistic training 
is currently in the form of self study, periodic shipboard 
lectures, seminars, drills, or attending one of the Navy's 
Bice Pighting Schools. Unfortunately, due to a busy ship's 
schedule and the high rate of shipboard personnel assignment 
rotations, these forms of training are sometimes unavailable 
or result in the pass or fail evaluation of the overall 
damage control supervisor's actions with little time for 
analyzing the individual team members' actions. A fire team 
is composed of personnel who are each trained for a specific 
fire fighting task which requires specific equipment. When 
a fire team member fails in the execution of his job or the 
operation of his equipment, the effectiveness of the damage 
control fire team in controlling a fire casualty is greatly 
diminished. 

To ensure a shipboard damage control fire team can be 
relied upon, cost andtime effective quality training 
opportunities must be available to ensure individual fire 
team members gain sufficient expertise at their respective 
jobs. Private tutoring is generally found to be the most 
effective form of instruction [Ref. 2: p.l]. Students 
working with private human tutors learn material up to four 
times as quickly as those in the typical classroom situation 


mef 2: p. 1). They attain a better grasp of the material 


than a comparable group of students spending the same. amount 
of time in the classroom [Ref. 2:  p. je The US Navy 
doesn't have the large number of human tutors required to 
support this fire team member tutoring concept on all of its 
ships. 

This study examines an alternative for the human tutor, 
namely a computer-based Artificially Intelligent Expert 
Tutoring System. Programmed with information from US Navy 


damage control references, it can Simulate shipboard fire 


casualty scenarios. This simulation is in the form of user 
displayed reports from the fire scene, including 
fire-related status, action-completed reports, 
action-incompleted reports, and personnel or equipment 


casualty reports. Personnel in this environment can be made 
aware of the overall effects of their seemingly isolated 
actions. The Tutoring System can ask questions, require 
responses to a given situation, and then provide the student 
with immediate results in the form of positive 
acknowledgement for correct responses or a well formed 
explanation of why the student's response was incorrect. A 
computer based Expert Damage Control Tutoring System, 
available twenty four hours a day on an inexpensive 
micro-computer, can provide a cost and time effective 
qualitv training environment for US Navv fire team 
personnel. 

Numerous expert tutoring systems, also known as 
Intelligent Computer Aided Instructional( ICAI) Systems, on a 
wide range of subjects. have been developed and are in 
operation today. SOPHIE teaches problem-solving skills in 
the context of a simulated electronics laboratory [Ref. 3: 
p. 247]. In that system, the problem facing the student is 
to find the faults in a malfunctioning piece of equipment 
whose characteristics he obtains by taking measurements. 
SCHOLAR tutors students about simple facts in South American 
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geography [ Ref. 3: p. Zoo. WHY tutors students in the 
causes of rainfall, a complex geophysical process that is a 
function of many” interrelated factors [Ref. 3: p. 242]. 


WEST is a computer-based learning environment in which the 


student is involved in an activity, like playing a computer 
game, and the program operates by "looking over his 
shoulder" during the game and occasionally offering 


criticisms or suggestions for improvement [Ref. 3: p. 254]. 
WUMPUS is a computer game in which a player must track down 


and slay the vicious Wumpus while avoiding pitfalls that 


result in certain fictional death. To be ae skilled 
Wumpus-hunter, one must know about logic, probability, 
decision theory, and geometry [Ref. 3: p. 261]. GUIDON, 


teaches students diagnostic problem-solving such as medical 
diagnosis. et contains an interactive dialogue for 


assisting a user in diagnosing a patient suspected of having 


an infectious disease (Ref. 4: pr). BUGGY can determine 
accurately a student's misconceptions( bugs) about basic 
arithmetic skills. It provides a mechanism for explaining 


why a student is making an arithmetic mistake, as opposed to 
simply identifying the mistake IRef. 3: p. 279]. EXCHECK 
provides a reactive environment, similar to SOPHIE, to track 
students progress in formulating arithmetic proofs [Ref. 3: 
p. 283]. SPIRIT, tutors probability theory, and is a system 
designed to evolve over time as the theory of student 
learning evolves [Ref. 5: p. 1]. The GEOMETRY TUTOR teaches 
high school geometry proofs [Ref. 6: pe) Ale A LISP 
PROGRAMMING tutor has been developed to help students learn 
tOuprogpam in LISP [Ref. 2: p. l. All of these ICAI 
Systems carry ona dialogue with the student and use the 
student's mistakes to diagnose his misunderstandings. 

This study discusses the design issues and the 
implementation of an ICAI system for tutoring fire team 


leaders in refining their knowledge and in performing their 


ae 


duties during simulated casualties. This ICAI system, the 
Fire Team Leader Learning Center, will henceforth be called 
"Eire". The research questions which this study addresses 
are the following: 

Le Is it feasible to develop an effective, challenging, 


expert, fire fighting aye em program, for the purpose 
Of Er ene team leaders in combatting fires on 
il 


US Naval Ships? 

2. Can a rule based expert system, which will correctly 
analyze. Symp oms and make proper decisions to 
extinguish ires, be derived from US Navy Damage 


Control Training references? 

The answers to these questions are pursued in Chapter III 
during the design and implementation of this system, and 
Chapter IV's feasibility study. These research questions 
are answered directly in Chapter V during the final summary. 

Nearly everyone who has written on the subject of 
computer-based education agrees that the potential is 
enormous. The question now is not whether computers will 
find a place in education but how [Ref. 7:p. SEE ICAI 
tutoring systems, such as Fire, is one feasible method in 
the US Navy. By providing a much needed one-on-one training 
environment for the fire teams' personnel, readily available 
on small micro-computers, the effectiveness and reliability 
of our Navy's Damage Control Organizations can be assured. 

The availability of a computer which can execute the 
PROLOG computer language is a prerequisite to implementing 
Fire. Chapter II provides the background on typical damage 
control training aboard US Navy ships. This background 
discussion includes present damage control organization 


training requirements, present methods of performing these 


requirements, and potential problems with the current 
training programs. Chapter III provides a complete 
discussion of the design and implementation of Fire. 


Chapter IV provides a discussion on the issues of using, 
refining, and expanding Fire. Chapter V is the Summary and 


provides a final discussion of the research questions. This 
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section also discusses some weaknesses with Fire and points 
out the benefits which the Navy can reap asa result of 
using ICAI damage control tutoring systems like Fire on its 
ships. Appendix A contains -an exhaustive user session 
listing demonstrating all of Fire's operations. Appendix B 


contains a listing of Fire's major supporting files. 


ie 


11. BACKGROUND 


A. SHIPBOARD DAMAGE CONTROL ORGANIZATION FOR FIRE FIGHTING 

For the orderly, efficient, and most expeditious 
employment of manpower and materials to fight a fire, ships 
survey their own conditions regarding the availability of 
men and materials. They then assign specific 
responsibilities, duties and employment, prepare and publish 
such information in a comprehensive and intelligible form 
called the "Fire Bill", and make it available to all 
personnel involved in such activities. The purpose of the 
Fire Bill is to establish a fire fighting organization and 
specify certain responsibilities for its direction to ensure 
that fires in ships are effectively fought and extinguished. 
While the ship is underway, the Repair Party personnel, who 
are members of the primary shipboard fire fighting team at 
sea, report to their General Quarters stations on Fire Call. 
While the ship is in port, the ship's Fire Bill may 
designate the Inport Fire Team as the primary fire fighting 
team. The Inport Fire Team is composed primarily of 
personnel in the regular damage control repair parties, 
resulting in each duty section having an effective fire 
fighting force. {Ref. 8: p. Cr 


B. SHIPBOARD DAMAGE CONTROL TRAINING PROGRAM 

The organization of a fire fighting team depends on the 
number of trained men available. A typical Inport Fire Team 
aboard an aircraft carrier consists of thirty people. A 


ship typically has six inport duty sections, each requiring 


its own fire party. This results in 180 personnel required 
for the Inport Fire Team Organization. These personnel are 
provided by every division on the ship. They are required 


to have met the damage control training requirements, 
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specified in the General Damage Control Qualification 
Standard required to be completed by all hands within 6 
months of reporting aboard. They also must meet the 


qualification requirements of their specific job on the fire 


teanm. 


Navy's 
These 


operational, 


witnessed and verified by qualification petty 


are 


Qualification 


Personnel Qualification 
qualification 


and hands on knowledge demonstrations 


subject matter 


Ref. 8: p: CLI) 


The qualification programs are 


the 


Program: 


administered under 
Standards( PQS) 
standards require theoretical, 
to be 
officers who 
The 


has 


experts. Control 


Standard 


General Damage 


alone over 80 knowledge 


demonstrations required to be performed. thembimet tol 


an individual on both General Damage Control andfor a 
specific job ona fire team can take up to 8 months 
depending on the individual's motivation and learning 
aba lity: In a shipboard environment, where personnel's 


tours of duty assignments rotate frequently, maintaining a 


Se manned, tralted, and fully qualified Inport Fire 
Team Organization is a big problem. 

which the 
shipboard damage control training programs must produce, is 


described in [Ref. 8: p. D2], 


The very high standard of Navy fire fighter, 


The Navy fire fighter acts with a thorough understanding 
of the means heat is transmitted. He knows all the 
eee les MNEWEĦ SELĦOL conditions at a fire and, even 

hough he may be unable to confine a fire within bounds, 
he should not be taken by surprise. He is always 
Eee make any rapid adjustment in fis 
extinguishing methods as the changes inthe fire 
boundaries require. ~~~ 


A Navy fire fighter should also "be able to combat, control, 


and extinguish practically any fire which could be 
encountered in a ship [Ref. 8: p. C13]. " 
The damage control training program is a bilateral 


system which includes both on and off the ship training. 
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The training opportunities available off the ship include a 


division damage control petty officer course, a refresher 
and advanced fire fighting course, a pipe patching course, 
and a repair party leader course. Shipboard continuing 
training programs include periodic "All Hands" basic damage 
Control training, lectures and seminars addressing 
damage-control-related topics, and realistic damage-control 


drills monitored by the ship's drill team. 

The method and effectiveness of the Inport Fire Team 
training programs have been a matter of concern for many 
years. In 1976, Bissel [Ref. 9: pp. 125-126] stated: 


— 


a 


The Inport Fire Party trainin is as important to the 
safety of the ship as the raining of the underwa 
battle-station repair parties. However, the i 
the inport fire party is often perfynctory, conn ts ae 
ro tal 


of a "muster with equipment” or a "walk ugh 

only. Those making assignments. O the 
dy, Cao ee eee arties often consider Mnuiot cme 
abilities necessary for the tasks assigned, only the 
requirement to provide a poli The. PESA training 
evolution should be an actual drill, emphasizin 

realistic symptoms, or as a minimum, a _forma 


instruction period on some phase of damage control. 


US Naval Ships today typically conduct an actuar dairy drip 
or formal instruction Tor inport fire teams. The 
difficulties which inherently affect the success of this 
training is the absence of an effective drill team present 
after normal working hours to conduct realistic drills, or 
100% attendance of team members for lectures when the 
subject matter doesn't relate to most of their fire team 
jobs. Again it is apparent that maintaining a stable 180 
manned, trained, and fully qualified inport fire team 
organization is a big problem. 

Effective fire teams gain experience and expertise 


primarily through numerous hours of realistic casualty drill 


training. This type of training is nore ly mitrat- Van 
knowledgeable drill team. They can supply realistic 
casualty symptoms(e.g., smoke, darkness, flames, personnel 
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injuries), Challenge fire team members by testing their 
abilities to carry out their jobs and operate equipment, 
provide a realistic shipwide casualty environment(e.g., 

alarms, shipwide announcements), and conduct an effective 


debriefing to critique each person's actions and evaluate 


the overall performance of the fire team. 


— a sa 


C. ALTERNATIVE TRAINING METHOD FOR INPORT FIRE TEAMS 
l; ICAI Inport Fire Team Tutoring Systems 
Intelligent Computer Aided Instructional computer 
programs are a costeeffective substitute for an absent 
knowledgeable drill team for training inport fire teams. 


They can provide realistic casualty symptoms, they can 


— a 


challenge each fire team member on an expert level, inwboth 
job responsibilities and equipment operations, they can 
provide a realistic shipboard environment, keep an accurate 
record of performance scores on all aspects of a casualty, 
and finally they can effectively tutor a team member when an 
incorrect action is taken. This study, discusses the design 


and implementation of an ICAI system for fire team member 


training. Using ICAI systems for inport fire team training 
provides, in a one-on-one tutoring environment, both 
effective casualty strategy training, and specific role 


domain and equipment knowledge training. Using ICAI systems 
in this manner, can significantly contribute to solving the 
problem of maintaining stable 180 manned, trained, and fully 
QUEME ¡nport fire team, organizations. 
2. Analysis of the Role of a Fire Team Leader 

Every inport fire team must have a Fire Team Leader 
who can effectively coordinate the efforts of his fire team 
personnel, and who is Knowledgeable in all functions and 
equipment which his team provides. A typical Inport Fire 
Team Organization is shown in Figure 2.1. Since the fire 
team leader is the most difficult member to replace, and 


Since all fire team members should be in training to become 
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a fire team leader, this study focuses on the developments 
of an ICAI tutoring system for training a fire team leader. 

In order to develop an ICAI tutoring system for a 
specific domain of interest, in this case a fire team 
leader, all aspects and characteristics of the domain must 
be well understood. A damage control fire team leader must 
be capable of making correct decisions during a changing 
casualty, based on his assessment of the current state of 
the casualty. Located a short distance from the actual 
space containing a fire, his assessment must be derived from 
the reports he receives from the scene. 

During actual shipboard casualties, scene reports 


can often change or contradict previous reports due to 


unexpected events. These unexpected events include—human 
errors, personnel casualties, fires _reflashing after 
previously being extinguished, and equipment malfunctions. 


He should take action to recover from personnel injuries, or 
malfunctioning equipment, before taking new actions’ to 
combat the fire. A fire team leader must continually be 
ranking his concerns as a result of the reports he receives. 

Unsatisfactorv or incomplete peperts from the scene 
must always be investigated by the fire team leader. If an 
unsatisfactory report of completion of an order is received, 


he should order that action again to ensure its satisfactory 


completion prior to continuing to the next major action. In 
general, there is a preferred order to complete major 
actions while combatting a fire. If one action is not 


completed properly prior to going to the next action, a bad 
consequence of prematurely continuing may occur. EON 
example, if only 90% of a fire is extinguished and the order 
to desmoke or remove the smoke from the space is ordered, 
the high rate of air flow from the desmoking fans will cause 
the fire to increase in intensity and refill the space. TE 


is imperative that a fire team leader understand the general 
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order of actions or strategy of combatting a@ tire and we, eo 
effectively concentrate his resources to carry out these 
actions. 

In: addition to strategic knowledge, the fire team 
leader must be an expert in the factual knowledge of his 
jos The factual knowledge of a fire team leader is 
understanding every member's job and equipment operations 
which fall under his control. This is necessary to 
differentiate between satisfactory and unsatisfactory 
reports. For example, he must understand the Oxygen 
Tester's job to recognize a report of 16% oxygen is 
unsatisfactory for human breathing, whereas 21% is 
satisfactory. The factual knowledge of a fire team leader 
covers a wide range of functions and equipments. 

The success of a fire team lies heavily on the 
overall strategic and factual knowledge of “the fire ceam 
leader. New fire team leaders are often weak in their 
knowledge of casualty control. This weakness, or 
inexperience, could result in the failure of the fire team 
to control a fire. This lack of control inlay ledd toma eiass 
of life or equipment. The shipboard damage control training 
program, with the aid of ICAI tutoring systems, can assist 
in ensuring that fire team members and leaders have mastered 
their strategic and factual Knowledge required for their 


specific jobs. 
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Pe lee: A EIRE T TEAM LEADER LEARNING CENTER 


A. FIRE SYSTEM CONFIGURATION AND DESCRIPTION 

Fire is an ICAI tutoring coaching system in which the 
user is a fire team leader and must direct a shipboard fire 
team through the actions of extinguishing a fire. The term 
"coach", describes a computer-based learning environment, in 
which the student is, involved in an activity, such as 
playing a computer game, and the instructional program 
operates by "looking over his shoulder" during the game and 
occasionally ofíers criticisms Or suggestions fOr 
improvement without destroying the student's fun at the game 
Beet. 3: Tp. 254]. To be a skilled fire team leader, one 
must know how to prioritize reports from the scene, be 
knowledgeable on all operations of fire team equipment and 
functions which the fire team provides, and be able O 
effectively respond to unexpected events, such as personnel 
casualties, broken equipment, or reflashing fires. The user 
is challenged in these areas in a computer game environment, 
where his experience level directly affects the fire 
scenario difficulty. In keeping with the philosophy of 
computer coaching, students become highly motivated to learn 
the fundamental fire team leader skills. 

The design of the Fire system involves the interactions 
of the specialist programs shown in Figure 3.1. The system 
has four special modes of operation. Three of these modes 
provide individual simulated fire team actions or equipment 
operations' training, which allows the user to concentrate 
on his weak knowledge areas. These three modes are the 
Individual Equipment Operations and Basic Damage Control 
Actions, the Individual Complex Damage Control Actions, and 
the Previous Fire Casualty Operations. The fourth mode of 


operation is the Complex Fire Casualty. 
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This mode provides a simulated complex shipboard fire 
casualty scenario where all damage-control-related actions 
must be executed correctly to remove the fire from the ship. 

Die central box of Figure 3.1 contains a tree model 
representation for an expert fire team leader's actions 
which are required to correctly execute any fire-related 
action or equipment operation. It is, in essence, a formal 
representation of an expert fire team leader's knowledge 
domain. The tree model utilizes a top-down design, using 
stepwise refinements of actions with the root as the most 
genetal saction, to the leaves eight levels below, which are 
specific action or equipment operations. The Game 
Environment uses this Action Tree Model to determine the 
scenario of the simulated fire casualties. The Student 
Model uses this Action Tree Model to determine the 
difference between the student's action tree and the 
expert's. Using this difference, the Student Model focuses 
on the most important action which the student forgot and 
communicates this information to the Tutoring Module. The 
Tutor derives relationships between actions from the Action 
Tree Model, which can be employed to improve its tutoring 
explanations, and allows the user opportunities to learn 
additional details of actions which were forgotten or 
incorrectly executed. 

All of the Fire system's modes of operations use four 
special modules and the Fire's Action Tree Model to carry 
out their operations. The four modules are the Game 
Environment, the Student/Expert Choice-Comparer, the Student 
Model, and the Tutoring Module. The Game Environment 
presents the scenario of the fire using random casualties 
and scene reports, provides user action menus for choosing 
the next preferred action, maintains the user's performance 
score, and provides a HELP facility. The Game Environment 


sends the user's next action choice and the Action Tree 
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Model expert's next action choice, to the Student/Expert 
Choice-Comparer to compare the two choices, and return 
control to the Game Environment if the choices agree. Upon 
disagreement, the Comparer module sends the user's choice to 
the Student Model. Using the Action Tree Model and the 
overlay model method [Ref. 3: p. 231), The Student Model 
determines how the student's action tree model differs from 
the expert's Action Tree Model. The Student Model then 
sends the most important action difference information to 
the Tutor. The Tutor, basically chooses a tutoring strategy 
based on the Kind of action error, as determined by sere 
Student Model, which the user has made. The Tutor presents 
an explanation to the user to correct his action error, and 
also provides the user an opportunity to learn more detailed 
information concerning his forgotten action or incorrectly 
executed action. 

The Fire system specialist programs, modules, and 


supporting features shown in Figure 3.1 will be described in 


complete detail in the rest of Chapter III. The details 
will provide, where appropriate, a description of the 
design, the design issues which were addressed, and 
implementation methods used. The novelty of this Fire 


system is that in a single system, there is significant fire 
team leader domain expertise, a broad range of possible 
interaction strategies available to the tutor, and a 
modeling capability for the student's current knowledge 
state. A listing of a user session demonstrating Fire's 
operation is contained in Appendix A. The Fire system's 
main program and major supporting procedure files are 


contained in Appendix B. 


B. FIRE SYSTEM DETAILED DESIGN AND DESCRIPTION 


1. Action Tree Model 
The Fire system's fire fighting related knowledge is 


stored ina tree data structure. The tree consists of 100 
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nodes, each representing an action which a fire team leader 
Must used to recover from a .shipboard fire. The node 
structure results from using a top-down stepwise refinement 
design methodology. The three types of actions nodes which 
make up the Action Tree Model are Expandable, 
Non-Expandable, and Test Procedure. The type of node is 
directly related to the complexity and makeup of the action 
which the node represents. The nodes each have a unique 
number which represents their unique location in the Action 
Tree Model. The structure of the tree and the location of 
each action's node, imposes a preferred order for action 


execution which an expert fire team leader would follow 


during a fire casualty. As a result of each action node's 
type, location, and relationship to neighboring action 
Bodes, the Action Tree Model is the driving force that 


Er cesa las pecto ehesoperationsof the Fire system. 
a. Action Node Descriptions 
(1) Expandable(ex) Action Nodes. An expandable 
action node in the Action Tree Model corresponds to an 
action which through stepwise refinements can be broken down 
into specific subactions which have a preferred order of 
execution. This results in each generalized high-level 
action being subdivided into more specific and detailed 
mien that, when properlv executed, will accomplish the 
high-level action. If the subactions are also of the 
expandable tvpe, then their subactions describe in greater 
detail the lower-level steps needed to accomplish a 
high-level action. This development in a "treelike" 
fashion, as shown in Figure 3.2, has a preferred left to 
right order of actions on all levels. [Ref. 10: p. 1651 
In general, there is a preferred order of 
performing major fire fighting actions. This is the reason 
the expandable node "treelike" data structure was chosen as 


the underlying structure for the Action Tree Model. some 
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Figure 3.2 Action Tree Model "treelike" Structure 
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nodes, typically the leaves of the tree data structure, are 
not expandable. These not expandable node types, will be 
discussed in section III.B.l.a.(2) and (3). To demonstrate 
the development of Fire's Action Tree Model, Figure 3.3 
shows the root of the tree as the action "Return the ship to 
normal operation. " This action is broken down into 
subactions which are further broken down. These subactions 
have a preferred order of execution as reflected in their 
numbering scheme(e.g., action 1.1.1 is performed prior to 
action 1.1.2, action 1.1 or its subactions must be completed 
enor EOusStarcing action l2 Or IES subactions). 
Characteristic of subactions of an expandable node action 
are the existence of bad consequences which can result when 


two consecutive subactions are performed out of order. 


1. Return the ship to normal operation. 
PEU TONE cae Lire. 


1.1.1 Isolate the fire. 

Further breakdown of action 1.1.1) 
1.1.2 Remove all fires. 

( Further breakdown of action 1.1.2) 


il mi after the fire. 

: emove all smoke from the peace. 
Further breakdown of -S LS 
est for sufficient oxyge 

, (Further B breakdown of ón LILA 

ewater the space. 
Further breakdown of action 1.2.3) 
ut away the fire Saeed aoa 
Further breakdown of action 

.5 Secure the fire team. l 

(Further breakdown of action 1.2.5) 


2 
ne 
aren 

2 

2 





Figure” 3. 3 Breakdown of an Expandable Action Node 


The expandable node "treelike" structure 
also represents the way a human expert fire team leader 
would approach a fire casualty. Upon hearing the 


announcement of a fire casualty, a fire team leader would 


2 


first think "What is my current most Important concern E 
is to "Return the ship to normal operation." But how do I 


"Return the ship to normal operation," oh by first "Putting 


out the fire," and then "Cleaning up after the fire." But 
how do I "Put out the fire?," oh by first "Isolating the 
fire," and then "Removing all fires" and so. on. Having a 


tutoring system which accurately reflects the way the 
student must think is critical to the success of an ICAI 
system. In [Ref. 3: p. 228], this philosophy is supported; 
"A good teacher must ‘understand what the student is doing, 
not just what he is supposed to do." 

Each expandable node represents a 
procedural expert in the corresponding subactions that a 
user must learn in order to acquire the skill in completing 
the high-level expandable node action. This is accomplished 
using a separate file of produetien rules for each 
expandable node action which acts as a small "expert system" 
for that node action. The node expert systems will, upon 
successful completion of a subaction based on an "OK" report 
.from the scene, proceed to its successor subaction as 
defined in the file's successor rules information table. If 
a subaction is not completed, a "not OK" report is received 
from the scene, and that subacrren más t A A again. 
This closely parallels how a fire team leader will act as a 
result of reports from the fire scene. The node expert 
system file framework is shown in Figure 3.4. 

For each subaction, a source file table 
contains a number description of the node, its source file 
name, and its node type. Expandable nodes and test 
procedure node type nodes actually have a corresponding 
source file. Non-Expandable node type nodes do not have 
corresponding source files. A role predicate exists which 
contains the title of the fire team member which this node 


action is directed towards. All of Fire's expandable node 
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File Name: action 

successor(action, State, Successor): - 
successor. rule info action, State, Successor), 
not( result(action, State, nok 


EMGCCEeGSOEMRUule Jnro( action,{1,...,0},i{l,...,1}). 
successor_rule_ A action, Rao A ] 


successor_rule_info( action, {1,...,X},complete). 


source file( action, j1,...,1},node file name,node type). 


source file( action, ae... ¿Xj node file name,node type). 


e aa FIRE TEAM LEADER’ ). 
etameaction,11,:.:,/01). 


/** Main Fire Program contains the following rule. **/ 
successor(_,State,State). 


Figure 3. 4 Expandable Node Action File Framework 


action roles are for the fire team leader, but they could be 
easily changed to any other member's role which the user 
must assume(e.g., medical corpman for the personnel casualty 
AGEJONS). Finally, a start predicate 1s required, whose 
dummy node number's successor is the firest subaction which 
will be performed. This initiates the correct execution of 
the remaining subactions in an order prescribed by the 
random report results received from the scene. With these 
numerous fire team member action procedural experts, the 
overall Action Tree Model assumes the expertise required of 
an expert fire team leader. 


(2) Non-Expandable( nex) Action Nodes. A 


non-expandable action node is the simplest of the node 


types. It corresponds to an action which does not breakdown 
into specific subactions or requires any supporting 
information. The non-expandable action node is always a 
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leaf on the Action Tree Model. It doesn't have a 
corresponding source file. It is always a subaction of an 


expandable node action as shown in Figure 3.5. 


1.1.1.1.3.3. Relieve the senior person in charge 
at the scene.(ex) 


1.1.1.1.3.3.1. When ready to receive briefing from 
the man in charge state to him, 
"I am ready to relieve you. (nex) 


1.1.1. 1.3.3.2. Receive briefing from man in charge: 
(Obtain who, what, when, where, 
and how, information about the 
casualty). (nex). 


When ready to take Salt Oa of the scene 


state, I relieve you. nex ) 
Announce to all personnel at the scene 


that you are the man in charge. (nex) 





Figure 3.5 Breakdown of an Expandable Action Node 
to Non-Expandable Action Nodes 


(3) Test Procedure( tp) Action Nodes. A test 
procedure node in the Action Tree Model corresponds to a 
basic action which doesn't breakdown like an expandable 
action node, but can be further described by supporting 


information. This supporting information can be in the form 


of a basic, easy to remember, step by step procedure, such 
as taking an oxygen test with a gas tester. This type of 
test procedure node will be Said to contain an 


"order-dependent" description. The other form of supporting 
information is amplifying information such as guidelines, 
advice, or safety precautions which should be followed 
during the execution of the test procedure node action. 
This type of test procedure node doesn't contain 
order-dependent information and will be said to contain an 
"informational" description. Test procedure nodes will 
always be leaf nodes on the Action Tree Model. They will 
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also always be subactions of expandable node actions as 


Shown in Figure 3.6. 


Test for sufficient oxygen. (ex) 
.2.1. Get the oxygen test equipment. (nex) 
.2.2. Test the oxygen test equipment. (tp) 
ES ina Satisfactory first oxygen test (tp) 


.2.4. Obtain a satisfactory second oxygen test. (tp) 





Figure 3.6 Breakdown of an Expandable Action Node 


to Test Procedure Action Nodes 


As previously discussed, order-dependent 
description test procedure action nodes, usually represent 
basic equipment operational procedures. Characteristic of 
these procedures are an order-dependent step-by-step 
procedure. A fire team leader must know these procedures, 
generally through memorization, so that the equipment will 
operate properly. These node's subactions differ from 
expandable node's subactions, in that, if they are performed 
out of order, the equipment being operated will not work 
properly, whereas expandable node subactions performed out 
of order may cause a potentially catastrophic bad 
consequence. These node action file's framework, shown in 
Figure 3.7, involve a series of operation steps listed in 


correct operational order, the action or task name which is 


also the file's name, and finally the reference which this 
action procedure was derived. ime Figure 3.6, action 
OA 2. Zee. Test the oxygen test equipment." is an 


order-dependent description test procedure node. 
Also as previously discussed, the 
informational description test procedure action nodes, 


usually represent non-order-dependent amplifying 


3l 


File Name: action_name 


operation_step( {'first action procedure step'}). 


operation_ step( {'last action procedure step'}). 


task_name( action_name). 
reference( reference _name). 





Figure 3.7 Order Dependent Description Test Procedure 


Action File Framework 


information. This information is generally in the form of 
guidelines, advice, or safety precautions which should be 
followed during the execution of these test procedure node's 
action. These node action file's framework, shown in Figure 
Sep is similar to Figure 3.7 but contains only one 
operation step predicate containing the entire text of 


amplifying information. 


File Name: action_name 
operacton S Cep A amplifying E Information 
"ENS Hee Text 


task Ponce! e e _name). 


reference( reference_name). 





Figure 3.8 Informational Description Test Procedure Node 


Action File Framework 


In Figure 3.093 àc tion Zas” and 1.2.2.4. are both 


informational description test procedure node actions. 


tid 


b. Top-Down Design 

The top-down design methodology used to design 
the Action Tree Model begins with the overall goal of a fire 
team leader, that is, con restoren" then ship to normal 
operation. Then a series of stepwise refinements were 
applied to develop a large tree model with a maximum depth 
of eight levels in some parts of the tree structure. The 
third level actions, being the more general descriptions of 
actions, represents a basic beginner's level of knowledge of 
a fire casualty: 
Isolate the fire. 
Remove all fires. 
Remove all smoke from the space. 
Test for sufficient oxygen. 
Dewater the space. 


Put away equipment. 


YO WM sp UNB 


secure the fire team 

As the action's are broken down into further subactions, 
each with important order dependence, the levels assume the 
"Advanced" and "Expert" knowledge levels of detailed fire 
fighting knowledge. As stated in [Ref. 11: p. 106], "the 
interesting feature of top-down refinement is the 
flexibility of the abstractions. Abstraction states are 
individually constructed to fit each problem in the domain." 
This is evident from Figure 3.3 where the abstract action 
1.1 is broken down into two subactions and action 1.2 is 
broken down into five subactions. 

The top-down design approach was instrumental in 
the transition from design to program implementation. As in 
structured programming, stubs [Ref. 10: p.167], were used 
for subactions which did not yet exist during the early 
stages of program implementation. This allowed the upper 
levels of the Action Tree Model to be tested, prior to the 


completion of the lower levels. 
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c. Action Node-Numbering System Description And 
Benefits 


The Action Tree Model consists of a hundred 


action nodes. Each action node has a unique number based on 
its location in the tree. The root of the tree is node 
number one and has the Prolog list representation of "{1}". 


The subactions of the root have numbers 1.1 and 1.2 and are 
represented in Prolog list format as "{1,1}" and "{1,2}" 
respectively. Assigning node numbers to actions results in 


the following benefits: 


l. Less programming errors due to easy-to-develop short 
numbers compared to numerous copies of action 
description character strings which ase” prened je 
misspe led words, extra Spaces? or incorrect use of 
apostrophe s in a Prolog environment. 

2: Vea, list processing rules, the node position 
location in the Action Tree Model can easily be 


determined. This information is critical in comparing 
a user s answer to the expert's answer and formulating 
the correct student knowledge model tutoring strategy. 

3. The node action's location is also useful in 
displaying a specific action node s. subactions inorder 
to teach a user a specific action. l 

4. The numerical value of the node number also dictates 
successor action relationships used in the overall 
action order control of the svstem game. 

The list format of the node number allows 
outstanding flexibility for the Action Tree Model for future 
changes or expansions. The current version of the Tree 
Model has a root number of "{1}" and contains an action node 
number "(1,1,1,1,1,3,1,2]" on the lowest level representing 
the action "Have personnel turn their helmet lights on." 
This particular action node is a non-expandable type node. 
But if next year, a complex two step procedure is developed 
for turning the helmet light on, then the easy modification 
to incorporate this change is to classify 
"$1,1,1,1,1,3,1,2]" as an expandable node type, designate 
two new action nodes "11,1,1,1 HS TT eR and 
"f1,1,1,1,1,3,1,2,2}" and develop them bese Mon Cheir A GIET 
node types. There are no other program coding changes to 


the Fire system for this action node expansion. If a new 
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type of explosive gas tester is developed and required to be 
used, then just change ONLY the test procedure files for 
nedes "{1,2,1,1,2}"(Have the explosive gas tester tested. ) 
eecmnode (1,2,1,1,3) "(Sample “the space which had the fire 
for explosive gases. ). There are no other program coding 
changes to the Fire system for this explosive gas tester 
change. The flexible node numbering system in addition to 
the fixed format of each node type source file allows easy, 
fast turn around maintenance periods in keeping the Action 
Tree Model's fire fighting knowledge current. Figure 3.9 is 
a partial display of the Action Model Tree with ali of its 


supporting features. A Casualty Tree Model, shown in Figure 


SILO. identical in structure to the Action Tree Model, 
implements the fire reflash, personnel casualty, and 
equipment failure casualties. The casualty scenario 


traverses both trees in a sequence directed by the Random 
Task Generator described in section III.B.2.a. 
2. Game Environment 

The Game Environment's purpose is to maintain the 
user's interest and motivate the young( generally 18-24 year 
old) fire team leaders, to use the Fire system. As in West 
and Wumpus, it also coordinates the user's presentation of a 
game scenario. In Fire, this is a realistic shipboard fire 
casualty scenario which is commensurate with the user's 
experience level. It randomly chooses scene reports based 
on the user's past performance and on his experience level 
to challenge potential weak knowledge areas. It provides 
challenging action menu's of variable lengths based on the 
user's experience level. A final performance report on all 
major fire fighting tasks which the user performed is 
displayed upon completion of the fire casualty scenario or 


upon exiting of the Fire system. 
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Restore Normal Operatio 
#1 (ex) CC #0 
Cleanup After The Fire 
#1.2 (ex) 
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Extinguish|l Verify 
All Fires 
LAS 


(tp) 


Deenergize 
Space 
E E a 


(ex) 

















Debrief 
the 


Fire Team 
HI Dl 
(tp) 








| Open 
[Circuit 


Locate 


Ċircuvet 






Breakers 
+1. 1 eee 


(tp) 


[Breakers 
ai E Ie 
(tp) 





Put Away 








SERQ 
, ` 
, 


Equipment 


Get 


Overhaul 





Put Helmet Check 





Equipment 






On +1.1.2.4.1|| Burnable 
PL LT (tp) Material 
(ex) Extinguished 






- >>. 
roo” wa sa 
- mo 
> a Fun, 


1.2. ae 
(nex) 


Turn Helmet 
Light On 
Xilel,1.1:.1. 37002 100 Action Nodes 


Casualty Code = C 


Notes: 


(nex) 


36 








Secure Thel 

Fire Team | 

41.2.5 
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8 Level Heirarchical Structure 


Figure 3.9 Partial Action Tree Model 


Many Levels 


Not Shown 


a. Random Task Generator( RTG) 


The purpose of the Random Task Generator is to 


generate, in a pseudo random fashion, a control mechanism 
for initiating unexpected events, such as personnel 
casualties, broken equipment, and fire reflashes. It also 


controls when a report from the scene reflects when a 
previous action wasn't completely accomplished. Its final 
purpose is to determine, based on a user's past performance 
on a task and his experience level, whether the user will be 
tested on the subactions of a higher-level task. This 
unanticipated directing of the specific subactions of a 
specific task, falls in the category of an unexpected event 
for a fire team leader. This Random Task Generator adds 
powerful realism to the shipboard fire casualty scenario. 
The user, just as a real fire team leader, can not 
anticipate every future action. He must continually analyze 
the reports he receives from the scene, rank his concerns, 
and when directed, carry out the detailed subactions of some 
tasks as would be required if a fire team member failed in 
his role responsibilities. 

The initiation of unexpected events 1s a 
mipetion of the user's experience level, his past 
performance on the specific unexpected event, anda random 
number in the range of one to a hundred. Each experience 
level is assigned a number which defines the number range or 
"unexpected event window", between it and a hundred where a 
random number must fall to cause the unexpected event to be 
executed. The experience levels, number assigned, and 


corresponding percent of the time unexpected events occur 


are: 
l1. Beginner 90 10% 
2. Advanced 75 257 
37 Experť i 60 40% 
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Handle All Casualties Immediately 


Handle Injured 
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Handle Equipmen 


Handle Reflash 
CC #1 
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CC = Casualty Code 
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Figure 3.10 Casualty Tree Model 
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This approach causes the scenario difficulty factor to 
increase as the user's experience level increases. An 
expert will receive 30% more casualties and unexpected 
events than a beginner. 

The unexpected event window can be enlarged or 
narrowed based on the user's past performance on a given 
task. If the user has a current performance score of 90% or 
better, for a specific unexpected event, then a -15 points 
is subtracted from the basic experience level number, which 
will marrow the window. In this case, the experience 
levels, numbers assigned, and corresponding percent of the 
time a particular unexpected event, which the user has 


performed well on, are: 


1. Beginner 105 0% 
2. Advanced 90 10% 
3. Expert 75 25% 


This approach results in the Fire system spending less time 
on the unexpected events that the user has already performed 
well on. i 

The unexpected event window is enlarged for 
tasks which have a previous performance of less than 90%. 
For these tasks, the number of points which were previously 
missed performing this task, are subtracted from the basic 
experience number up to a maximum of 25. In this case, the 
experience levels, maximum numbers assigned, and 
corresponding percent of the time a particular unexpected 


event, which the user has done poorly on, are: 


i. Beginner 65 337 
2. Advanced 50 50% 
3. Expert 35 695% 


This approach results in the Fire system spending a greater 
percent of its time on unexpected events that the user has 
performed poorly on. This repetition of poorly performed 


tasks allows the user to "learn by doing" the task over and 
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over until his performance improves and consequently the 
unexpected event window will narrow and the event will then 
occur less frequently. 

The control of personnel, broken equipment, and 
fire reflash casualties is described in section III.B.2.b. 
In controlling the reports from the scene, in order to 
provide some not fully completed action reports, a biased 
random number generator is used. For every node action in 
the Action Tree Model, an action result predicate exists 
which contains "OK", or action completed reports, and "NOK", 
or action not fully completed reports. One example of this 


predicate is shown in Figure 3.11. 


Action Node: node_action( {1,2,2,3}, . 
{'Obtain a satisfactory first oxygen test. },tp). 


/* Two OK reports exists. The RTG also determines 
which of the two reports to display when an OK 
report is chosen. 

aca results( mainfire, § 2:3, OK, 


172 
The imee oryn fest has been completed 
Sa eee oa }, {' The first oxygen test 
indicates 2 3). 


% oxygen. '} 


/* Two NOK reports exists. The first would test 
his specific knowledge of oxygen test results 
the other on his alertness on scene report 
content: tm 

action results(mainfire,{1,2,2,3}, nok, l 

ihe first oxygen test indicated 1% oxygen. }, 
The first oxygen test has not yet been 
performed. Wap 


/* Node action casualty related information is also 
contained in this predicaten" 
action_results(mainfire, {1,2 e . } 
ilhe Oi EA EE GAS meter need e is missing, 
The oxvgen tester s sample hose is damaged. ) 





Figure 3.11 Node Action Scene Report Predicate 


The biased random generator forces an "OK" report to be 
displayed to the user two of every three times on the 


average. This allows just enough "NOK" reports to the scene 
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leader to test his awareness to scene reports, and his 
specific fire fighting knowledge for recognizing when an 
action hasn't been completed. If this random number 
generator isn't biased, the "NOK" reports "seem" to appear 
almost every time and the the user gets into a routine of 
almost immediately reordering every action without really 
analyzing the reports. This really lengthens the game time 
and distracts the user from enjoying the game environment. 
Since the Random Task Generator directly effects 
the scenario of the fire casualty, in order to receive a 
different scenario every time a user plays, true randomness 
properties must be achieved. These characteristics are 
approached in two ways. First, as shown in Figure 3.12 the 
user 1S required to put in the time of day upon beginning 
the program. This time of day, a number between l and 2400, 
Vemisede co initialize or "seed" the Random Task Generator. 
This will result in the beginning of the scenario to be 


different for different times of the day. 


jekk Fire System Welcome Message Beginning ***/ 


Welcome, I am an EXPERT in FIRE FIGHTING and DAMAGE 
CONTROL! “I am ready to challenge your knowledge as 


a fire team scene leader or supervisor! 
Please enter your NAME: User Name 


User Name, please enter the time of day( 0001-2400): 0830 
Thank You. 





kmgure 3.12 Initial Seeding of the Random Task 


Generator Using the Time of Day 


Secondly, to prevent the user from receiving the same 
scenario by entering the exact same time of day every time 
he uses the program, the Random Task Generator inherits an 


unpredictable or random characteristic property by changing 
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the seed every time the Tutoring Module is used. The exact 
times when a user will make incorrect actions during the 
scenario is unpredictable. The Tutoring Module is used only 
when incorrect actions are entered by the user. Therefore, 
these properties of the Random Task Generator ensures that 
the user is effectively challenged in an unpredictable 
environment and developes expertise in the domain of fire 
team leader fire fighting knowledge. 

| b. Task Executor 

The purpose of the Task Executor 1s to direct 
the user interface presentation of the subactions of a 
designated high-level fire fighting action or task, inorder 
to thoroughly test the user's knowledge corresponding to 
this task. The interface presentation includes reports from 
the scene, action menus of variable length, and requests for 
user's interactive action inputs. The Task Executor can 
execute both expandable node actions and test procedure node 
actions. The user's input, along with the Action Tree Model 
expert's choice, of the the correct next action, are both 
sent to the Student/Expert Choice-Comparer module for 
deliberation. 

Expandable node actions are executed by loading 
in their respective source file containing successor rule 
information. The decision on the next best action to take by 
this procedural expert is based on the last "OK" or "NOK" or 
casualty report received. The user is also tested in this 
specific situation. The user's choice of action is compared 
with the Action Tree Model expert's choice, and if correct, 
the user is given credit and the game continues, otherwise 
the user takes a "trip" to the Tutoring Module to learn why 
he was incorrect. This use of "immediate feedback" for 
incorrect user choices will be described in section III.B.5. 

Upon returning from the Tutoring Module, the 


Task Executor will call upon the Random Task Generator to 
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decide if a user should be forced to perform the subactions 


ef the particular subaction of the task which.is currently 


being performed. As previously discussed, this depends 
largely on the user's experience level, and his past 
performance on this particular subaction. If he is directed 


to perform the subactions of a particular task subaction, 


shown in Figure 3.13, a recursive call to the Task Executor 
will be made passing it the particular subaction which will 
become the new task to be executed. These recursive calls 


can continue to all levels of the Action Tree Model. 


User Name's Score Level 
50% 


o 


SO E 
User Name, you are the "FIRE TEAM LEADER". 


FIRE TEAM LEADER, E MUST now DIRECT THE ACTIONS 
to complete the following TASK: Set fire boundaries. 


FIRE TEAM LEADER, indicate your most important, 
or next action to be completed. 


1. Send fire peu aay teams to each adjacent 
space with Pagan e fire equipment in order _. 
ee anna the boundaries are containing the fire. 
y all fires are out. A 
Conduct a debriefing of the fire casualty 
Ween ecthe fire team. , 
Send fire boundary teams to shut all physical 
openings to the space with the fire. 
Lead the fire team to the Repair Locker. 
Have Repair Locker locate on ship s compartment 
drawings all adjacent spaces and all physical 
openings to the space including doors, ventilation 
ducts, and drains. 


HELP 
QUIT 





Figure 3.13 Display of Task Executor Directing User 


to Perform a Particular Task 


Test procedure node actions are executed using a 
different method as a result of their quite different 


subaction descriptions, as described in section 
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LSE et a) The order-dependent test procedure node 
actions, contain easy, step-by-step, fire fighting 
procedures, which should be simple tasks for a fire team 
leader. They should be second nature to a fire team leader 
such as the sequence of steps to start an oxygen breathing 
apparatus, or how to test an oxygen tester. To test the 
fire team leader's knowledge, the list of operational steps 
from the task's source file are randomly mixed up twice, 


this results in two mixed up lists of steps and the original 


correct list of operational steps. These three lists are 
presented to the user one at a time. If he recognizes the 
Correct se; he is awarded a point for the task and the 
Fire system game continues. Otherwise he is informed that 


he is incorrect, and the correct order is displayed for him 
to learn before he continues with the Fire system game. An 
example of this procedure is shown in Figure 3.14. 

The informational test procedure node actions, 
contain guidelines, advice, or safety precautions which 
should be followed while performing the node action. Since 
this information is often "nice to kmew sor "philosophical; 
there is no absolute requirement that a fire team leader 
must follow it. Yet, in general, Lt Will aicdħhim san 
correctly and safely carrying out a specific node action. 
Therefore, upon executing these test procedures files, their 
textual content is displayed for the user to review and 
learn before he continues with the Fire system game. Their 
is no test or grade associated with these procedures. An 
example of this procedure is shown in Figure 3.15. 

When a particular task subaction or its 
subactions have been completed, a node action related 
casualty may occur. The majority of the Action Tree Model 
node's actions have a casualty associated with them. The 
three types of possible casualties, with their corresponding 


casualty number code, are: 
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User Name, are the following steps the correct sequence 
to perform the task: 


Test the oxygen test equipment. 


1. Pull the knob down and adjust the flame to 
approximately 3/8 inch in height. Allow the flame to 
burn about 5 minutes to reach its normal operating 
Eomperature, 

Blow against the flame and gaskets to test the lamp 
fam leakage. , , 

Push on the relighter handle( igniter) and slide it 
up as far as 1t will go. Turn the relighter handle 
and ignite the wick. 

4. Turn up the wick using the wick adjuster. 


Enter a "yes. no. ": yes. 

User Name, you are incorrect, the above sequence is not 
correct! Below is the correct sequence, 

STUDY AND LEARN it before you continue. 


Turn up the wick using the wick adjuster. 
Push on the relighter handle(igniter) and slide it 
up as far as it will go. Turn the relighter handle 
and ignite the wick. , 

Pb tne kKneb dewn and adjust the flame to 

o ma tel y 3/8 inch in height. Allow the flame 
to burn about 5 minutes to reach its normal 

mA EEI temperature. 

Blow against the aoe and gaskets to test the lamp 
for leakage. Lea 


age will cause the flame to 
flicker.. 





Figure 3.14 Display of an Order Dependent 


Test Procedure Action Node 


l. Reflash of the Fire. 

2. Personnel Injury. 

3. Broken or Malfunctioning Equipment 
The node's casualty code and associated scene reports are 
contained in the "action_results" predicate shown in Figure 
Sel: The Random Task Generator will determine whether to 
initiate one of these casualty tasks. This initiation would 
be done by making a recursive call on the Task Executor with 
the casualty name as the new task to be executed, otherwise 
the next task subaction would be chosen based on the last 
scene reports. Example scene reports for the Fire system 


casualties are shown in Figure 3.15. 
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kok *  KNOWEEDGE REVIEWS 
User Name, you will be shown a review of important 
knowledge required in the performance of Task: 


Obtain a satisfactory first Oxygen Test. 
STUDY AND LEARN THIS INFORMATION and for further 


uidance refer to reference: 
FLAME SAFETY LAMP, NAVEDTRA 465-08-00-82, p.1l. 


ANALYZING THE OXYGEN TEST SAMPLE 
If the flame grows dim, the oxygen content is lower 


then normal. Access to the space is permitted only 
under conditions of extreme need, and then only for 
limited periods of time. No routine work is to be 
conducted under this condition. If the fame dies out, 
there is less than 16 percent oxygen by volume. 

the flame flares up brightly, there 1s a Tean 
concentration of explosive gases or vapors. If the | 
flame goes) one with a slight pop, there is an explosive 
concentration of gases or vapors. If the flame flares 
up and then goes out, there is a rich concentration 
of explosive gases or vapors. If no explosive gases 
are present and there is sufficient oxygen to sustain 
life, work in the compartment may proceed. 





Figure 93915 Display of an Informational 
Test Procedure Action Node 


FIRE TEAM LEADER, yon THEN receive the following 

report: Desmoking has stopped due to large flames in 
the space. 

or 
Large flames have been reported in the 
vicinity of the Reflash Watch. 

Or 


The overhaul equipment shovel has broken. 


Or 
The explosive gas tester meter has no needle. 
Or 
A man has fallen and is unconscious while 
trying to close a ventilation duct damper. 
or 
The electrician was shocked at the electrical 


panel. 3 





Figure 3.16 Examples of Casualty Scene Reports 
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c. User Action Menus 
As the Fire system Task Executor traverses 
through the Action Tree Model, which formulates a unique 
casualty scenario, the user must choose a correct "next 
eee from a menu of fire fighting actions for every 
situation. In order to add a greater degree of difficulty 
as the user experience level increases, the number of menu 


action items presented are: 


1. Beginner = 
2. Advanced 6 
3. 'BEmpert 12 


The menu items are made up of the correct next action, as 
chosen by the Action Tree Model expert, a nearly equal 


number of actions which come directly before and directly 


after the correct action in the Action Tree Model, and when 
required, "fill in action items" randomly chosen from the 
fourth level of the Action Tree-Model . Listing Ehemrenu in 


this way focuses the attention on all the specific actions 
which are closely related to the correct next action. The 
fire team leader will not be able to ignore obviously wrong 
actions and easily choose the correct next action because 
there will generally be several listed actions which should 
be performed during the current time frame. This approach 
forces the user to rank his present concerns and learn the 
fine, important, order-related differences between actions. 
A "HELP FACILITY" anda program "QUIT" feature are also 
listed at the end of the menu available to the user at all 
times. An example of the user action menu is shown in 
fulġure' 3, 13. 
d. User Performance Report 

The Fire svstem's Complex Fire Casualtv mode 

presents a realistic presentation of a complete shipboard 


fire scenario consisting of numerous events or tasks. A 
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goal of a fire team leader is to successfully recover from a 
fire casualty in the most effective manner. An ICAI 
tutoring system, which provides only an overall running 
score of performance, is a poor evaluator of the potential 
of a future fire team leader. iI fuser anor 1 performs ten 


tasks to complete a fire, each with a performance score of 


70%, then his overall performance score would be 70%. But 
if user no. 2 performs the same ten tasks, and his scores 


are 90% on seven tasks, with the remainder tasks' scores of 
25%, 25%, and 20%, then his overall score is also 70%. BUE 
clearly, user no. 2 has a much greater potential to be a 


good fire team leader for the following reasons. 


1. USer mo. 2 has demonstrated that (he 15 camane or 
achieving outstanding performance grades of 90% on 
seven of the fire Lighting actions ETLE Fid ting 
tasks concepts are usually equal in difficulty in 
learning. ser no. 2, given some more time, has the 
capability, to master he three other actions and 
become an effective Fire Team Leader. 

2.1 USEEM No 1 either doesn't have the intelligence 
capabilitv to master the ten fire fighting tasks or 
as the number of tasks increases, user no. i has 


difficuli an O the sequence in which the 
Pidicate that usar no 1 current a poe TM 
to be an effective Fire Team Leader. 
A tutoring system needs to know how the student has done 
with respect to each sub-skill involved in problem solving 
[Ref. 5: p. 22m 
The Fire System provides a Performance Report, 
Shown in Figure 3.17, which gives the overall score and all 
of the individual fire fighting task scores which were 
tested. Using this report, the user can identify his 
specific weak areas and using the alternate training modes 
of the Fire system, he can train specifically on these 
tasks. This report is presented upon completion of the 
complex fire casualty or when a user exits the program using 


the QUIT action menu option. 
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FINAL GRADE OF PERFORMANCE 
Congratulations User Name you've survived! 


Remember there's always room for improvement in Damage 
Control Casualty Training. Your life, your shipmate's, 
and ya ship s survival may someday depend on your 
KNOWLEDGE as a MAN IN CHARG of a casualty. The 
following is a report of your performance: 


Casualty Task Points Total Percent Grade 
Overall Score 36 47 e 


Broken aeni pmont Casualty 
Pts 7 Total = 9 Percent Grade 78 


Extinguish all the fires 
Pts = 


l Total = 1 Percent Grade = 100 


Have a smoke removal path established. 
Pts = 1 Total = 1 Percent Grade = 100 


Desmoke the space. 
Pts = 3 Total = 3 Percent Grade = 100 


Injured Person Casualty. 
Pts = 6 Total = 6 Percent Grade 100 


Main Fire 
Pts = 18 Total = 27 Percent Grade 66.6 


For further training on the types of damage control 

actions or equipment operations you just directed: 

micer a 1. To Quit N 
2. Previous Fire Casualty Operations Training 





Figure 3.17 User Performance Report 


e. Help Facility 

A fire system Help Facility is always available 
to the user as an item on the action menu. Its purpose is 
to provide a brief description of the modes of operation, 
the standard user menu and performance score, the operation 
of the Tutoring Module, the effect of the user's experience 
level on the difficulty of the scenario, and the QUIT option 
of exiting the system. In keeping with the philosophy of 
realism in training a user to be a fire team leader 
controlling an actual casualty, the user must be forced to 


Know exactly what he is doing with little time to ask for 
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"help." This concept is enforced by removing one point from 
the user's overall score whenever the Help Facility is used. 
The introduction to the Help Facility is shown in Figure 
Sa LOs 


DAMAGE CONTROL FIRE TEAM LEADER LEARNING CENTER 
HELP FACICITY 


— This "LEARNING CENTER" was developed Sy LT Steve 
Weingart USN as a research project in deve yea an 
expert system tutorial program associated with the 
instruction of shipboard fire team leaders. The 
major goal of this system is,to train a fire team. 
leader to direct a fire team s actions in combatting 


a fire in a computer simulated shipboard casualty 


environment. The LEARNING CENTER s major training 
mode of operation is the Complex Fire Casualtv Mode, 
which places sane user as the fire team leader in a 
simulated shipboard fire casualty environment. 

He/She will have to respond to various reports from the 
scene which, as in an actual E g are sometimes 
contradictory, inaccurate, or complete, or contain 

new information on new casualties, such as broken 
equipment, injured personnel, or reflashes of fires. 





Figure 3.18 Help Facility Introduction 


ju Student/Expert Choice-Comparer 
The purpose of the Student/Expert Choice-Comparer is 


to perform a simple comparison of the chosen action node 
numbers. If the node numbers agree, then the user is 
awarded credit for a correct answer and the Fire system 
control returns to the Game Environment to continue the 
casualty scenario. If the node numbers disagree, the user's 
node action number is sent to the Student Model module for 
analysis for follow on tutoring. 
4. Student Model 

A detailed model of a student's knowledge that 

indicates his or her misconceptions is important for 


successful tutoring (Ref. 3: p. 279]. 


The student modeling module represents the student's 
understanding of the material to be taught. Much recent 
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ICAI research has focused on this component. The 
purpose of modeling the student is to make hypotheses 
about his misconceptions and suboptimal performance 
strategies so that the tutoring module can point them 
Wt, indicate why they are wrong, and suggest 
corrections. 


[Ref. 3: p. 231] Most current ICAI tutoring systems have a 
student model module for detecting student misconceptions. 
The Fire system has a student model module using the form of 
an "overlay model" [Ref. 3: p. 231]. 

In an overlay model, the student's understanding is 


represented completely in terms of the expertise component 


of the program. This determines where the student's 
knowledge and the expert's knowledge differs. The analysis 
of this difference, is the key to determining the best 
method of tutoring the student back to an expert's level of 
knowledge. Other current ICAI tutoring systems using the 
overlay model include GUIDON [Ref. 3: p. 267], and WEST 
[Ref. 3: p. 254]. The Fire system's expert fire fighting 


knowledge is the complex structure of node actions and their 
respective files contained in the Action Tree Model. 
Conceptually, a non-expert student's knowledge tree, shown 
in Figure 3.19, looks identical to the Action Tree Model 
except some action nodes are missing, out of position, or 
contain incomplete or inaccurate procedural knowledge. By 
"overlaying" this imperfect student tree model over the Fire 
system's Action Tree Model, the differences requiring 
correction by a tutor are evident. 

The Fire system, as a result of the flexible Action 
Tree Model and node numbering system, can easily determine 
the student's knowledge model using only the previously 
completed action, the user's wrong choice, and the active 
casualty code. Since the Fire system uses immediate 
feedback upon an incorrect answer, it is assumed that the 
user has performed or been tutored to an expert's level of 


performance up to the previous correct chosen action. Using 


SI 


Restore Normal Operatio 
#1 (ex) | 
Put Out The Fire Cleanup After The Fire 
#1.1 (ex) #1.2 (ex) 
Isolate The Fire 
#1.1.1 (ex) 
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Overhaul 
Put Helmet Equipment Check 
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Many Levels 
tr Not Shown 


Note: 100 Action Nodes 
8 Level Heirarchical Structure 


Figure 3.19 Student’s Knowledge Tree Model 
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the relationship between the previous action node and the 


user's. present incorrect action node, and the active 
casualty code, the following six different student model 


error cases can be detected. 


il 


Wrong Task--When an Injured Personnel Broken 
Equipment, or Fire ReflaSh casualty task has been 
activated, as evident by a nonzero casualty code, _the 
fire casualty scenario traverses the Casualty Tree 
Model shown in Figure 3.10. A Wrong Task error occurs 
in this situation, when a user chooses an action on 
the Action Tree Model shown in Figure 3.9, which 
Beeaees tO the task of Returning the ship to normal 
operation”, rather then the activated casualty. 


Weak Casualty Knowledge--When an Injured Personnel or 
Broken E casualty task is active, as evident 
by a casualty code of two or three, the fire casualty 
scenario traverses the casualt code two or three's 
subtree of the Casualty Tree Model shown in Figure 
3: A Weak Casualty Knowledge error occurs when a 
user Choses the wrong casualty control recovery action 
(i.e. ae. action node no. 2.2 before action node 
no. : 


peer etn Completed ee Loh = ene fire casualty 
scenario traverses the Action Tree Model when the 
casualty code is Zero. A Forgetting Completed Action 
BRBROFMOECUES when a user chooses an action, other then 
the previousl Gompletecdgactlonz which ħas alreadv 
been completed. For example, His rror would eae tr 


.if the user had just completed the action no. 


ieee oS But. Away Equipment, and then. chooses no. 
1.1.1.2 Deenergize Space, or action no. al o 
Poe On Helmet, idibbhe f fltonamthe Correct choice of 
action no. 1.2.5.3.4 Dismiss Reflash Watch. Using the 
Action Tree Model, this error is detected when a user 
chooses any node action to the left of the previously 
Ene SEC action node or to the left of any of its 
ancestors. 


Unsure Action Knowledge--In both the Action Tree Model 
and the e Tree Model shown in Figures 3.9 and 
O respectively, an Unsure Action Knowledge Error 
occurs when a user chooses the _immediate previously 
completed node action. For example, this error occurs 


Ac user has just completed action node no. 
Ia A Ġets Overhaul Equipment, and he chooses 
action node no. 1.1.2.4.1 Get Overhaul Equipment, 


rather than action node no. 1.1.2.4.2 Check Burnable 
Material Extinguished. 


Transposition Error--In both the Action Tree Model and 
the Casualty Tree Model shown _in Figures 3.9 and 3.10 
respectively, a Transposition Error occurs when a user 
chooses a Mode action which is to the right of the 
Gorse ame Choice node action or to the right of an 
Bmeestor of the correct action node. mirei S 
situation a search is made for the largest and 
ae level not-yet-performed Action Tree Model 
MOS which has been forgotten entirely by the user, 
or has been transposed with the user s choice node or 


CMEMOf Lts ancestor nodes. sen, eel cue IE UE e 
Seo eens error occurs if the previously completed 
action node was mo. 1.2.5.3.2(not shown) and the user 


chooses no. 1.2.5.3.4 Dismiss Reflash Watch, then the 
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user has transposed the correct node no. ( 1.2.5.3.3 
with node no. 1.2.5.3.4. The more interesting example 
is if tche previonsiy completed action node was no. 
u 
El 


+ 
1.1.2.4 Verity Fire t, and the user chooses node no. 


1.2.5.1 Debrief the Fire Team. In this example the 
user has transposed the action. node no. 1.2.4(not 
shown) with action node no. 1.2.5 Secure the Fire 


Team. 


6. Incomplete Action Knowledge--In both the Action Tree 
Model and the Casualty Tree Model shown in Figures 3.9 
and 3.10 respectively, an Incompleted Action Knowledge 
error occurs when he user doesn t re-choose the 
previously chosen action which wasn t properly 
completed. This error differs from the transposition 


error in that the user o L, chosen the 
correct action node, reflecting. that his Knowledge 
Tree doesn t transpose that action node with other 
action nodes. This error case reflects, the user's 


failure to realize that the action wasn t properl 
' completed, as evident by the_ last "NOK" scene repor 

as described in section lft. BaZa. For example, in 

Figure 3.9, this error occurs when a PE U B DM 


chosen action was action node no. lege l Locate 
Circuit Breakers, and a NOK reponi is received 
concern cht Ss aceon, and then the user chooses 
action node no. 1.1.1.2.2 Open Circuit Breakers. 


A student model must provide "a detailed analysis of 
each portion of the student's solution as necessary in order 
to diagnose errors" [Ref. 2: p. 9]. The Fire system's 
Student Model, using the Action Tree Model data structure 
and the current State of the game environment, fulfills this 
requirement which enables the Tutoring Module to provide the 
student user with the best appropriate guidance. 

5. Tutoring Module 

The tutoring module of ICAI systems must integrate 
knowledge about teaching methods, user explanation formats, 
and the knowledge domain of interest. A recent teaching 
strategy that has been successfully implemented on several 
systems is called "coaching." Coaching programs are not 
concerned with covering a predetermined lesson plan within a 
fixed time. Rather, the goal of coaching is to encourage 
skill acquisition and general problem-solving abilities by 
engaging the student in some activity like a computer game. 
In a coaching situation, the immediate aim of the student is 
to have fun, and skill acquisition is an indirect 


consequence. A successful computer coach must be able to 
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discern what skills or knowledge the student might acquire, 
based on his playing style, and to judge effective ways to 
intercede in the game and offer advice. The Fire system 
uses the coaching teaching strategy. [Ref. 3: p. 234] 

The question of "when" a coach should interrupt the 
game is a complex issue and, in most ICAI coaching systems, 
depends on the knowledge domain being taught. Rather than 
allowing a student to perform more than one incorrect action 
without any feedback, most current systems including The 
Geometry Tutor [Ref. 6: p. 1], The LISP Programming Tutor 
meee 1], SPIRIT {[Ref. S: p. 1], and WEST [Ref. 3: p. 
257), use the "immediate feedback" method [Ref. 2: p. 9]. 
This method is executed by keeping the tutoring module 
quietly in the background while the user inputs correct 
answers. If an incorrect input is diagnosed, then the 
tutoring module interrupts with advice. 

The Fire system has adapted the immediate feedback 
interruption method primarily because a fire casualty 
scenario which allows more than one incorrect action, as in 
a real fire, would create an unpredictable course of events 
and result in confusing a student fire team leader. Eor 
example, given a fire casualty scenario status in which the 
fire has been extinguished and a reflash safety watch has 
been set. Then the fire team leader fails to order the 
compartment to be overhauled to verify no smoking embers 
exist, and fails to perform explosive gas tests. He then 
goes ahead and performs the next action of turning on blower 
fans to remove the smoke from the space. Now the scenario 
could change in numerous different ways, such as, the fan 
explodes due to explosive gases which may or may not cause 
personnel casualties or new fires. A different scenario is 
that the space is filled with fire due to the presence of 
hot embers and air flow from the fan. Therefore, to train 


the user what the correct order of recovery actions are, and 
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why they are performed in a specific order, immediate 
feedback is used to focus the user's attention on each of 
his specific actions in order to understand their sole 
impact if performed improperly. 

The Fire system's Tutoring Module functions include 
correction of the user's misunderstandings and to provide 
the user an opportunity to take a time out from the game 
environment and learn about the action in which the user has 
exhibited a weakness. The user's misunderstandings, as 
detected by the Student Model, are addressed and approached 
uSing a different explanation strategy for each of the six 
error cases discussed in setion II11.B. 4. Additional 
tutoring information concerning the specific subactions or 
descriptions of the action missed is also available to the 
user prior to returning to the Game Environment. Using the 
Tutoring Module effectively, a user will not only learn why 
his answer is not the best choice of actions, but also be 
"steered" back in the direction of the correct answer. 

a. Tutoring Strategies 

By using the Student Model determined error 
case, the user's choice, and the last scene report, the 
Tutoring Module can effectively tutor the user on six 
different knowledge related concepts. Explanations 


developed for tutoring purposes were designed to be short, 


direct, easily understandable, and clearly displayed. The 
Tutoring Module is similar to SPIRIT [Ref. 5: p. 10], and 
the LISP Tutor [Ref. 2: p. 10], in that it will make the 
student user find the answer by himself. A short 


description of the six conceptual error cases' tutoring 
strategies addressed by this Tutoring Module follows. Their 
individual error case Student Model detection schemes are 


described in section III.B.4. 
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(9h) Case l: Wrong Task Error. The Wrong Task 
Error could result from the user not comprehending the 


casualty initiation information of the last scene report. It 
could also result from the user not "keeping the big 
picture” regarding the numerous actions that need to be 
acted upon and choosing randomly what to do next. This 
behavior, representing a user which has lost his ability to 
rank his many concerns, would lead to very unsafe conditions 
in a real fire. 

The tutoring strategy, shown in Figure 
3.20, used for this situation, is one that forces the user 
to refocus his attention on the immediate problem at hand. 
This is accomplished by politely informing him that his last 
action is not even relevant to what should be his highest 
Petortey, wamely a personnel “injury or equipment casualty, 
and then to "steer" him in the right direction by reminding 
him of the last scene report. This strategy closely 
parallels real fire situations where a good fire team 
member, who upon hearing the casualty related report from 
the scene and observeing the fire team leader order an 
action totally unrelated to the problem at hand, will 
quickly speak up and advise the leader that his action is 


incorrect and remind the leader of the last scene report. 


User Name, your choice of: 
Choose and activate a drain method type. 


has nothing to do with the current most important 


action to be performed. The LAST REPORT: 
The fire team is at the scene but the sound powered 
phones do not work. 


should help you decide what to do next. 





Eigure 3. 20 Wrong Task Tutoring Strategv 
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(2) Case 2: Weak Casualty Knowledge. The Weak 
Casualty Knowledge error case could result again from the 
user not comprehending the casualty initiation information 
of the last scene report or the user being weak in knowing 
the correct order the casualty recovery actions should be 
performed. This case appears only in the Complex Fire 
Casualty mode of operation which is discussed in section 
111.C.3. This user behavior generally represents a fire team 
leader with poor potential to control and recover from 
unexpected events, such as personnel, equipment, or fire 
reflash casualties. 
The tutoring strategy, shown in Figure 
3.21, used for this situation, is based on the philosophy 
that the potential casualty immediate recovery actions for 
personnel, equipment, or fire reflash casualties must be 
known by a fire team leader in a complex fire scenario. In 
recovering from a real shipboard fire, if these casualties 
occur, and are not effectively and quickly handled, a high 
probability of loss of life or increased equipment damage 
will result. Therefore, the user is given a very strong and 
direct report that he is taking the wrong action for the 
current casualty state. No hint of the correct action is 
given, which will force a poor fire team leader to continue 
to flounder, causing his casualty subtask score to reflect 
this weakness. A good leader, who knows his casualty 
recovery actions, will determine for himself the correct 
action and maintain a satisfactory casualty subtask score. 
(3) Case 3: Forgetting Completed Action. The 
Forgetting Completed Action error case could result froma 
conservative user which has difficulty in keeping "the big 


picture," 


and when in doubt as to whether he has already 
completed some action, he reorders its completion. This 
case could also result from the user not thoroughly 


understanding the subaction of a specific action. This 
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User Name, ou_have FAILED TO REALIZE that a REFLASH, 
PERSONNEL INJURY or EQUIPMENT FAILURE CASUALTY has 
et 0 SS or you've taken the WRONG IMMEDIATE 


You MUST take the CORRECT IMMEDIATE ACTIONS in the 
ĠA A JER to CONTROL and RECOVER from this 





Eure 3.21 Weak Casualty Knowledge Tutoring Strategy 


could lead him to thinking an action hasn't been completely 
performed when in fact it has. This error, ina real 
Shipboard fire, can only indirectly lead to a more dangerous 
Situation as a result of the time wasted to recomplete an 
AGGTON. During this time, a fire could possibly grow in 
intensity or spread to adjacent spaces. This situation of 
wasting time recompleting an already completed action would 
rarely occur. Generally a good fire team member, usually 
the fire team leader's phone talker, reminds the leader that 
his ordered action had already been completed. 
The tutoring strategy, shown in Figure 
3.22, used in this situation, is to inform the user that he 
has already completed a specific action. He will then be 
shown the subactions of the task which he thought wasn't 
completed to give him a thorough understanding of that task. 
If the user desires, he can learn more about these 
subactions by asking the Tutoring Module for further 
eraining of this specific action using the Action Node 
Breakdown feature described in section III.B.5.b. He will 
then have to determine for himself what is the next best 
action to perform. 
(4) Case 4: Unsure Action Knowledde. The 
Unsure Action Knowledge error case results from a user not 
comprehending the last scene teport's implication that the 


previously ordered action has been completed. This case 
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User Name, YOU HAVE ALREADY COMPLETED the action: 
Get to the scene equipped and ready to go. 


STUDY AND LEARN the following information to help you 
next time you have a similar situation. Below is a 
breakdown of the specific subactions, which make up 
the action: Get to the scene equipped and ready to go. 


1. Get the fire team dressed. 
Get the fire team to the scene: 
Take charge of the scene. . 
Establish phone communications with the 
Repair Locker. 
Charge the fire hoses. 





Figure 3.22 Forgetting Completed Action Tutoring Strategy 


could also result from a user not understanding thoroughly 
the subactions of the previous action. This would be 
evident of a user who had received reports that each 
subaction had been completed, but still didn't think the 
action was now considered complete. As in Case 3, this 
could only indirectly lead to a more dangerous fire casualty 
as a result of wasting valuable time recompleting this 
aceron: 

The tutoring strategy, shown in Figure 
3.23, is to force the user to refocus his attention on the 
last scene report and inform him that the report implied the 
previous action was complete. He will then be shown the 
subactions of the previous action, which he thought wasn't 
completed, to give him a thorough understanding of that 
task. If the user desires, he can learn more about these 
subactions by asking the Tutoring Module for further 
training of this previous action's subactions using the 
Action Node Breakdown feature described in section 3.B.5.b. 
The user will then have to determine for himself what is the 


next best action to perform. 


a) 
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ooer iame, the LAST REPORT: | 
The Explosive Gas tests indicate negative explosive 
gas. 


SHOULD HAVE indicated to vou that the action: 
Perform explosive gas tests. 


has JUST BEEN COMPLETED. 


STUDY AND LEARN the following information to help you 
next time you have a similar situation. Below is a 
breakdown of the specific subactions, which make up 
the action: Perform explosive gas tests. 


Get Se IO gas tester. 


Havemt 
Sample the space, 
explosive gases. 


e explosive oe tester tested. 
which had the fire, for 





Figure 3.23 Unsure Action Knowledge Tutoring Strategy 


(MM Ca seb: TInaħsposjtion Error. The 
Transposition Error case results from a user not 


understanding the correct order which the recovery actions 
are to be performed, or either forgets, or never had the 
knowledge, of the correct action or its higher level 
governing action, which should now be performed. Both of 
these causes are signs of a potentially poor fire team 
leader who currently is not capable of effectively directing 
the fire team. He also doesn't understand the reasons for 
executing the recovery actions in a prescribed order or the 
potentially bad consequences which could result from not 
performing the correct action at the proper time. 

The tutoring strategy, shown in Figure 
3.24, is to focus on why the user's choice of actions or the 
higher level concept action which his action belongs, is 
incorrect. This is accomplished by describing a potentially 
bad consequence which could occur as a result of not 
performing the immediate predecessor's highest level missed 
ation: The user is first reminded of his action or its 


higher level conceptual action which he has chosen. Then 
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the user is informed that he must first perform the 
immediate predecessor action to this action. This immediate 
predecessor may or may not be the actual correct answer. 
This approach is to "steer" the user back in the direction 
of the correct action. If a user has chosen an action which 
is very distant from the previous correct action, this 
tutoring strategy will provide an explanation using very 


high level concepts. This enables the user to understand 


more easily his conceptual error. For example, if a user 
should have chosen the action, "Set Fire Boundaries.", but 
instead chose to "Secure the Fire Team.", the Tutoring 


Module would find the highest level ancestor node action of 
these actions to "steer" the user back. The explanation 
would inform the user that before he could "Cleanup After 
the Fire," he first must "Put the Fire Out." 

To teach the user the potential impact of 
forgetting or transposing his choice's immediate predecessor 
action and his chosen action, a bad consequence explanation 
is presented. This bad consequence addresses these actions, 
which were apparently transposed, and attempts to clearly 
emphasize andmake a lasting impression on the user why 
these action should never be transposed. 

The bad consequence explanation predicate, 
shown in Figure 3.25, consists of two sequential action node 
numbers located on the same level of the Action Tree Model, 
and the corresponding textual description of the bad 
consequence. If a bad consequence description was required 
for every node with every other node in the Action Tree 
Model, then for N nodes, N-Squared bad consequence 
descriptions would be required. This is not desirable for 
many reasons. A user is only tested on a local area of the 
Action Tree Model for each situation. This area generally 
includes the correct answer's immediate predecessors and 


successors. Also, it doesn't make sense for subaction nodes 
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User Name, BEFORE you can perform the action: 
Set fire boundaries. 


YOU MUST FIRST perform the action: 
Deenergize the space. 


OTHERWISE |, 

NE Ae. Ss Source is electrical, it will continue 
Pome tae Litres drow am intensity and if the fire $ 
source wasn t_ electrical, electrical cabling in the 
fire space will soon breakdown due to the heat and 
cause new fires. 


STUDY AND LEARN the following information to help you 
next time you have a similar situation. Below is a 
breakdown of the specific subactions, which make up the 
action: Deenergize the space. 


1. Have Repair Locker locate on the ship's electrical 
drawings all circuit breakers which isolate 
electrical power to the space on fire. 

2. Send electrician to locate and open all circuit 
breakers which isolate electrical power to the 
Space on fire. 





Figure 3.24 Transposition Error Tutoring Strategy 


to be related to their ancestors or descendents using bad 
consequence descriptions. Finally, the excessive memory 
requirements to store these additional descriptions and the 
resulting slower Game Environment response time would 
detract from the Tutoring Module's training effectiveness. 
An upper bound for the number of bad 
consequence descriptions required for the Action Tree Model 
structure can easily be determined. A bad consequence 
description is required for every action node and its 
immediate predecessor node, if one exists. In. Bou creme Z , 
the left most nodes on each level do not have predecessors. 
The number of left most nodes is equal to the number, L, of 
levels. If the Action Tree Model consisted of N nodes and 
all nodes were expandable nodes except the bottom level 
nodes, then the number of bad consequence descriptions 
required would be N-L. But in Figure 3.9, the Action Tree 


Model has test procedure and non-expandable nodes on levels 
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other than the bottom level. This results in some internal 
tree nodes not having immediate predecessors and 
consequently no required bad consequence descriptions. 
Since the location of these nodes is determined by the 
specific actions which make up the Action Tree Model, the 
exact number of bad consequences which aren't required 
cannot be exactly determined for any general action tree 
model. Therefore, an Action Tree Model, with N nodes and L 
levels, requires at most N-L bad consequence descriptions. 
Fire's Action Tree Model has 100 nodes, 8 levels, and 89 bad 
consequences. 

Following the bad consequence explanation, 
the user is shown a description or the subactions of the 
immediate predecessor action to his chosen action. Since he 
may have forgotten this action or has no Knowledge of it, 
this display will give him ‘time to tnonougily ear oe 
Actes If the user desires, he can learn more about these 
subactions by “asking the Tutoring @iioaute for cuen 
training on these subactions using the Action Node Breakdown 
feature described in section III.B.5.b. 

(6) Case 6: Incomplete Action Knowledge. The 
Incomplete Action Knowledge error case results from a user 
not understanding all of the subactions of a given action. 
This is evident when a user prematurely chooses the next 
sequential ordered action when the previous action hasn't 
been completed. The tutoring strategy, shown in Figure 
3.26, used for this situation, forces the user to focus his 
attention on the last scene report and informs him that the 
report implied the previous action hasn't been completed. 
He is then shown the subaction of the previous action which 
he thought was completed to give him a thorough 
understanding of that action. If the user desires, he can 
learn more about the subactions by asking the Tutoring 


Module for further training on these subactions using the 
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' eck; frame, center line relationship,', 
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node_action( {1 1 hy dae, 3 

i Have Repair Locker’ locate’ on the ship $ > 
compartment drawings the space with the fire.'}). 


ey 2, 2} eel, Ly Z; 1,3} 
,a lot of time will be wasted trying to randomly’, 
, Locate a space number on any of a number of 
charts. Using the deck, frames, center line 
relationship numbers the correct chart and space', 
can quickly be located. J: 
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bad consequence (f 
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ene ire re lashes the overhaul team Come per | 
anra n tie space, resulting in possible , 
personnel injury wj no fire extinguishing ', 
equipment present. }). 


node_action ‘Verify all fires are out. '}). 
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baqgure. 3.25 Examples of Bad Consequence Explanation 


Predicates 


Aetion Node Breakdown feature described in section 
AAB: 5. D. He will then determine for himself what is the 
next best action. 
b. Action Node Breakdown Feature 
The second function of the Tutoring Module 
discussed in section III.B.5, allows the user an opportunity 
to take a "time out" from the Fire system Game Environment, 


and pursue additional tutoring on the description or 


subactions of a particular action which the user 
demonstrated a weakness. Using the flexible structure of 
the Action Tree Model, and the easily manipulative 


node-numbering system, any particular action node can easily 
be located along with its subaction nodes. Consequently, 
the subaction nodes can also be described in the same manner 
until leaf action nodes are encountered. This feature, as 


shown in Figures 3.27, 3.28, and 3.29, allows the user to 
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User Name, your PREVIOUS ACTION: 
Take charge of the scene. 


hasn't been BOM Leter ee You SHOULD 
HAVE REALIZED THIS by the LAST REPORT you received: 


It isn't clear who is in charge of the scene. 
STUDY AND LEARN the following information to help you 


next time you have a similar situation. Below is a 
breakdown of the Pa subactions, which make up 
the action: Take Charge of the scene. 


1. Visually assess the status of the casualty control 
pr ceou nas in progress. l 

2. Identify the senior person in charge at the scene. 

3. Relieve the senior person in charge at the scene. 





Figure 3.26 Incomplete Action Knowledge Tutoring Strategy 


designate which subaction he desires further breakdowns on, 
inorder to reveal their subactions or descriptions. When 
the user has completed his review of an action's subactions, 


he is 


STUDY AND LEARN the following information to help you 
next time you have a similar situation. Below is a 
breakdown of the specific subactions, which make up 
the action: Get to the scene equipped and ready to go. 


Get the fire team dressed. 
Get the fire team to the scene. 
Take charge of the scene. 


Repair Locker. 


2 
oe 
4, Establish phone communications with the 
2 Charge the fire hoses. 


ns? 


want more breakdowns of these A 


o you 
INDÍCATE WHICH SUBACTIONS USING FORMAT 
one aS ENTER "c." to continue. 


, 





EITGWEER3 27 Action Node Breakdown Feature Displav One 


returned to the Game Environment and presented with the 
exact same game * state situation, as shown . in Figure 3.30, 


which he just made an error on. This allows him an 
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*** REMINDER OF PREVIOUS ACTION BREAKDOWN kk 
Below is a breakdown of the specific subactions, which 
make up the action: 

Get to the scene equipped and ready to go. 


Get the fire team dressed. 

Get the fire team to the scene. 

Take charge of the scene. 

Establish phone communications with the 
Repair Locker. 

Charge the fire hoses. 


*** NEW SUBACTION BREAKDOWN *** 
Below is a breakdown of the specific subactions, 
which make up the action: 
Get the fire team dressed. 


l. Dress the fire team in Battle Dress. 
2. Dress the fire team in OBA's 
3. Equip the fire team with fire fighting equipment. 


Do To want more breakdowns of these BR a non: 
INDICATE WHICH SUBACTIONS USING FORMAT °{#,#}. 
otherwise ENTER "c." to continue. 





Figure 3.28 Action Node Breakdown Feature Display Two 


opportunity to immediatedly correct his last knowledge error 
as a result of what he learned during his "trip" to the 


Tutoring Module. 


C. SPECIAL SYSTEM MODES OF OPERATION 


e Individual Equipment Operations and Basic Damage 
Control Actions 


This mode of operation allows a user an opportunity 
to learn about new basic tasks or concentrate on relearning 
basic tasks which have given him trouble. The user can 
choose from a list of 25 tasks which include individual 
equipment operations or basic damage control actions. He 
can choose the tasks in any order he prefers to learn them. 


Specific tasks will be displayed with the reference which 


the specific task knowledge test is taken. All of these 
tasks are Test Procedure Node Actions as described in 
section III.B.1.a.(3), and executed as described in section 
MI. B.2.b. Following the completion of the user's tasks, 
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kkk REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific subactions, which 
make up the action: | 
Get to the scene equipped and ready to go. 


Get the fire team dressed. 

Get the fire team to the scene. 

Take charge of the scene. f 
Establish phone communications with the 
Repair Locker. 

Charge the fire hoses. 


*** NEW SUBACTION BREAKDOWN TAR 
Below is a breakdown of the specific subactions, 
which make up the action: | 
Establish phone communications with the Repair Locker. 


Hold the set of phones in your left hand. 

Unhook the right side of the neck strap from the 
breastpi atoma the strap around your neck, and 
then fasten it to the breastplate again. 

Put the earphones on and adjust the headband so 
that the center of the ear piece is directly over 
the open Pun into the ear... 

Insert the plug into the jack box and screw the 
collar on firm Y- , i l l 
Adjust the mouthpiece to bring it directly in front 
of your mouth when you stand erect: 

Test the phones with someone on the circuit. 


Do you want more breakdowns of these subactions? 


INDICATE WHICH SUBACTIONS USING FORMAT 


+, +}. 
otherwise ENTER 'c. to continue. l 





Figure 3.29 Action Node Breakdown Feature Display Three 


the Fire system will exit, requiring restarting of the 
program for further training. 
2i Indiyidual Complex Damage Control Actions 

This mode of operation allows a user an opportunity 
to learn new complex tasks or concentrate on relearning 
complex tasks which have given him trouble. Again, he can 
choose in any order, up to 25 different tasks. All of these 
tasks are Expandable Node Actions, as described in section 
IIL B: a: (1p and executed as described in section 
li lee. ie The individual tasks are presented exactly as 
they would be in the Complex Fire Casualty mode. Upon 


completion of each task, the user will be given his 
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User Name, now that you understand why your last 
choice of actions wasn't the best choice, I'll repeat 
the last report you received and the same choices. 
CHOOSE THE BEST ACTION. GOOD LUCK! ; 
User Name's Score Level 
of 237 
User Name, you are the "FIRE TEAM LEADER." 


YOUR LAST REPORT WAS: 


The fire team is at the scene but the sound powered 
phones do not work. 


FIRE TEAM LEADER, indicate your most important, 


or next action to be completed. 
Deenergize the space. 
Have fire team member recheck proper operation of 
malfunctioning seamen t. 
If equipment ıs still malfunctioning, check local 
area for replacement. , 
Choose and activate a drain method type. 
Have a second team member check for proper 
eee On of the equipment. 
Obtain a satisfactory first Oxygen Test. 


HELP 
. QUIT 


"On A Ob UU Ne 





Figure 3.30 Post Tutoring Module Trip Displav 


performance score for that task. All incorrect answers will 
be addressed by the Fire system's Tutoring Module as 
described in section III.B.5. One exception, is whena 
casualty task is presented, and actions are chosen out of 
order, a detailed explanation of why the user's choice was 
incorrect will be given. Following the completion of the 
user's tasks, the Fire system will exit, requiring 
restarting of the program for further training. 
3. Complex Fire Casualty 

This mode of operation is the primary method of 
using the Fire system. It places the user in the role of a 
shipboard Fire Team Leader directing a fire fighting team in 
a simulated fire casualty environment. This mode is 
executed using all functions and features described in 


section III.B. The simulated main fire casualty scenario 
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begins with a shipwide announcement of the fire's type and 
location and ends when the fire team and reflash watch have 
been secured. Following the completion of the Performance 
Report display, as discussed in section 111.B.2.d, the user 
will have an opportunity to "QUIT" or choose the mode of 
operation described in the next section. 
4. Previous Fire Casualty Operation Training 
This mode of operation allows the user to be 


retested on the tasks which he just performed in the Complex 


Fire Casualty mode. © The tasks are sorted with the best 
performance first, worst next, second best third, second 
worst fourth, and so on. This order keeps the user's 


interest and motivation high, even during tasks which he 
didn't do well in before. These individual tasks are 
presented in a Similar manner as they were in the Complex 
Fire Casualty mode. Upon completion of each task, the user. 
will be able to see his score for that task. Following the 
completion of the previous tasks; the Pire system willje 2a 


requiring restarting the program for further training. 
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Ive USING THE FIRE SYSTEM ON US NA Sates 


A. MEMORY REQUIREMENTS 

To analyze the feasibility of using the Fire system ona 
microcomputer aboard US Naval ships, the memory requirements 
for the system's files must not be excessive. The Fire 
system's files were transferred from a VAX 11/780 Unix file 
system to a standard 9.25 inch, one sided, double density 
floppy disc, via a Tandy 1000 personal computer. The main 
program and its seven major Supporting files consume 128K 
bytes of memory. The other 54 supporting node action files 
consumed 72K bytes of memory. Therefore, the Fire system's 
memory requirements were 200K bytes of a possible 360K bytes 
available on this floppy disc. The Prolog-86 Interpretter 
[Ref. 12: p. 1], required to execute the Fire system on a 
microcomputer requires approximately 100K bytes of memory. 
Therefore, the Fire system and the required Prolog-86 
Interpretter can easily fit on one floppy disc which is very 
convenient in an on board microcomputer training 


environment. 


B. PROGRAM LANGUAGE REQUIREMENT 

The Fire system was developed on a VAX 11/780 Unix 
System. This system uses the Prolog language as described 
in Cocksin and Mellish (Ref. 13: p.1]. The Clocksin and 
Mellish Prolog, with a few minor code changes, can be 
converted to meet Prolog-86 code requirements, a 


microcomputer version of Prolog. 
Ce EXPANDING THE FIRE SYSTEM FOR DIFFERENT KNOWLEDGE 
DOMAINS 


The Fire system, as shown in Figure 3.1, consists of 
four modes of operation, four special modules, and an Action 


Tree Model. The Action Tree Model contains almost all of 
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the Fire Team Leader's expert level domain knowledge. 
Casualty team leaders for fire teams, flooding teams, 
medical emergency teams, and numerous other casualty teams 
required on US Naval ships, have very similar control or 
strategy knowledge. They all act on reports from the 
immediate casualty scene to determine their course of 
action. The Fire system structure Can be converted to train 
these other types of casualty team leaders by swapping out 
the Fire Team Leader Action Tree Model for another casualty 
leader's Action Tree Model. This ICAI tutoring concept, 
would be very valuable in a shipboard training environment 
where the main Fire system could be loaded into a 
microcomputer followed by any one of many casualty team 
leaders’ Action Tree Models which the user requires 


training: 
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V. SUMMARY 


A. DISCUSSION OF THE RESEARCH QUESTIONS 

This study was undertaken to develop a solution to the 
problem of keeping stable, trained, and fully qualified 
Tapert fire team Organizations on US Naval ships. 
Intelligent Computer Aided Instructional( ICAI) EUtOrIna 
systems were proposed to significantly reduce the training 
time while increasing the quality of the individual training 
for damage control personnel. To investigate this proposal, 
a Fire Team Leader ICAI Tutoring System was developed. Its 
design and implementation issues were described in Chaper 
TT. The written references for this ICAI system's fire 
team leader's knowledge domain development were common 
damage control references found on-all US Naval ships. The 
feasibility of actually using this Fire Team Leader Learning 
Center System, or Fire, was investigated in Chaper IV. 

Chapter IV demonstrated that it is feasible to use an 
ICAI tutoring system, such as Fire, on a microcomputer on 
board every US Naval ship. The only material's required are 
a microcomputer, a copy of the Prolog 86 Interpreter, the 
Fire system program and supporting files on floppy discs, 
and a Megabyte of memory. Chapter III's description of the 
functions and features of the Fire system provide a 
challenging, realistic training environment for fire team 
leaders to combat computer simulated fires. Therefore, the 
answer to the first research question this study asks is 
"ves", it is feasible to develop an effective, challenging, 
expert, fire fighting system program, for the purpose of 
training fire team leaders in combatting fires on US Naval 
Ships. 

ICAI tutoring systems, which tutor a student towards an 


expert level of knowledge in an area such as fire fighting, 
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require both strategic, or control knowledge, along with 
factual knowledge. The strategic knowledge is instrumental 
in determining the use of factual knowledge for different 
scenario situations. US Navy damage control references, 
used to aid in the development of the Fire Team Leader 
Learning Center, were good in the factual knowledge of how 
to operate equipment or how to perform certain damage 
control related actions. But they were poor in describing 
the strategic knowledge which fire team leaders should have 
and expert behaving programs require. IThis information 
tells why one action is performed rather than another action 
for a given situation. This "why information" gives each 
action a reason for existing in the Action Model Tree, in 
that bv performing it correct? at the right time, 
prevents a potentiallv bad consequence which otherwise might 
OCGUE: The "why information" implemented in this Fire 
system was based on the author's previous shipboard drill 
training environment experience and partially on damage 
control reference manuals. Therefore, the answer to the 
second research question this thesis addresses is that a 
rule based expert system, which will correctly analyze 
casualty symptoms and make proper decisions to extinguish 
fires, can only be partially derived from US Navy Damage 


Control Training references. 


B: ICAI TUTORING SXSTEM LIMITATIONS 
l1. Realistic Simulation 
The success of an ICAI Tutoring system such as Fire, 


relies heavily on a realistic simulation of a shipboard 


fire. Fire's simulation of a fire is implemented using 
textual report descriptions which originate at a 
hypothetical fire casualty scene. This approach was 


justified by stating that an actual fire team leader's 
location on a ship is not at the compartment of the fire, 


and therefore he only understands the fire's status from the 
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reports he receives from the fire scene. This simulation 
still only partially reflects a real shipboard casualty 
environment. A real fire team leader also has the sense of 
sight, allowing him to visually see which equipment is 
present, resulting in no unnecessary orders such as "Get the 
Oxygen Tester". Using his sense of smell, the real fire 
team leader can sometimes detect when smoke is spreading to 
adjacent spaces. Finally, using his sense of feel, the fire 
team leader can feel the heat generated by the fire, which 
based on its changing intensity, would reflect if the fire 
is increasing or decreasing in size. The fire team leader, 
who wears an oxygen breathing apparatus and protective fire 
fighting clothing, will often times not be able to use his 
sense of smell or feel. 

In order to incorporate the sense of sight, Fire 
could be incorporated onto a graphics capable computer or be 
accompanied by a detailed picture book for different fire 
scenarios. In addition to the scene reports which Fire 
displays, a graphical presentation displaying the equipment, 
smoke, people and other objects which a Fire Team Leader can 
see could be displayed. This system would provide a more 
realistic simulation, more entertaining ICAI tutoring 
system, anda more effective training environment then the 
basic Fire system described in this thesis. 

2. Action Tree Model Accuracy 

The knowledge which can be learned from Fire is only 
as good as the development of the Action Tree Model. The 
primary question of whether the US Navy's Fire Fighting 
Policies can be properly implemented in this structure is 
the key to the accuracy of the Action Tree Model. The 
development of an Action Tree Model to accurately reflect 
how to combat a fire oma US Navy ship is lial S Unie 
because: 

Ir fire is different and sometimes there are more 


than one correct sequence of steps in combatting the 
Game fire. 
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2. US Navy Damage Control references focus, in most 
cases on the basics of fire fighting using simple 


examples. These references provide very little 
assistance in determining whic actions are more 
important, or must be performed rior. tOo.-qotbew 
actions. The reasons, or potentiallv bad consequences 
relating to the importance of one action over another 
action are seldom given. This lack of information 


results in the Fire system's programmer having to make 
decisions which may not correspond to the existing 
Navy's policies. 

3. To prevent the tutoring system knowledge from becoming 
out dated, the Action Tree Model must be adaptable to 
frequently changing Navy — policies o E fire 
A PE or equipment requirement changes. 

C 


Fire's ion Tree Model is adaptable to these changes 


as deseribed in section [lier isc. 
3. Knowledge Base Structure 

The Fire system's knowledge base required structure 
needs to represent all possible states which a fire casualty 
could be in. Traversing this structure from a given start 
state, such as "announce the fire casualty", to a goal 
state, such as "the fire is out and the ship restored to 
normal operation", a path of actions could be followed by a 
ICAT "SYStenm cowl iver ss Cudencc. The first structure for the 
Action Tree Model which was chosen was a means-ends analysis 
approach as described in [Ref. 14: p.146-156]. This 
structure used a difference-procedure table which allowed 
procedures or next actions to be chosen which would reduce 
the difference between the current state and the goal-—state. 
Each next action chosen, contained preconditions or other 
actions which had to be completed prior to using the desired 
action: The Means-Ends Analysis method works very well for 
problems where manv actions have the same preconditions so 
that numerous paths could be evaluated and the shortest 
path, or least number of actions, could be found to arrive 
at the goal state. 

In the fire casualty problem-solving domain, the 
recovery actions which must be used to traverse from the 
start state to the goal state are all unrelated actions. 
These actions are unrelated in respect to having no common 
preconditions which would allow multiple paths to the goal 
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state. The recovery actions do have a preferred order of 
execution. This results in every recovery action becoming a 
direct precondition of its successor action. For example, 
the precondition of "Perform the Second Oxygen Test" is 
"Perform the First Oxygen Test". The precondition of 
"Perform the First Oxygen Test" is "Test the Oxygen Test 
Equipment". Applying - the means-ends-analysis approach to 
this problem domain results in one long sequential list of 
actions to be performed to reach the goal state. This 
approach was not chosen for Fire's Action Tree Model. The 
resulting simple sequential list of actions generated by 
this approach were contained in a complex 
difference-procedure table which executes numerous recursive 
calls. This would have resulted in a slower response ICAI 
tutoring system. It was also a complex issue to teach the 
subactions of aparticular action to a student while the 
system was executing the difference-procedure table. 

The Action Tree Model structure which was chosen is 
a multi-level top-down designed tree structure. This 
structure worked well for actions which contained distinct 
subactions which are performed in a preferred order. These 
subactions could also be further broken down into their 
subparts. For these types of actions, which had many levels 
of subdivisions, this structure was very effective in 
teaching complex actions by learning the numerous basic 
subactions which make up the complex action. Students which 
have difficulty in learning the subactions of a particular 
action, can be tutored using higher level, more general 
conceptual descriptions of actions which also contain those 
subactions. Fore- Ctions which do not contain distinct 
ordered subactions, it is unclear if the action should stand 
alone, such as Fire's non-expandable node actions or whether 
some form of amplifying information should be presented 


which could effectively teach the action. 
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The Fire system used both order-dependent and 
informational test procedure nodes to reflect the nodes 
which contained amplifying information. Type classifying 
the action nodes is based on the amount of knowledge the 
designer has for each node action. If the designer of the 
Action Tree Model cannot find sufficient knowledge about a 
particular action from a reference book or a human expert, 
the action node will probably be classified non-expandable 
and not taught very well to the user. If some information 
can be found about an action, but not enough to describe 
exactly what the subactions are and the reasons for the 
order they're performed, then the action node will be 
classified a test procedure node. In some test procedure 
nodes, amplifying information such as safety precautions or 
guidelines for performing the action can confuse rather then 
teach a student. If everything is known about an action, 
including all of its subactions and the reasons for their 
order of execution, then the action node is classified an 
expandable node and a user can be taught everything about 
that action. 

The design of an Action Tree Model should strive to 
contain expandable action nodes on all but the last level of 
its tree structure. This cannot always be accomplished. 
Actions cannot always be broken down into the same number of 
subdivisions. In summary, Fire's Action Tree Model 
structure was chosen because it was easy to traverse from an 
initial start state to a goal state along its fourth level, 
and also allowed an easy method to teach the student user 
the subactions of higher-level actions. 

4. Careless Errors 

Most ICAI tutoring systems address the issue of 
dealing with the "careless error”. The careless error 
occurs when a user chooses an answer without using any 


thought process. For example, the user doesn't read the 
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Ae TonHmenús displayed in Fire and enters a "1." each time. 
The Fire system doesn't utilize dummy menu items for 
detecting careless errors such as the action "Go Fishing". 
The action menus often contain fill in action items, as 
described in section III.B.2.c, which if chosen, will result 
in one line responses such as "You've already completed that 


AMO... or “That action™has nothing to do with the current 


most important action which should be performed". Generally 
careless users will receive these short tutoring reports. 


The careless user's scores suffer from careless errors. 


C. BENEFITS OF RESEARCH 

This study investigated the concept of using ICAI 
tutoring systems for administering individual training for 
US Naval personnel in damage control fire fighting 
principles. This research can also result in benefits in 
other areas of shipboard training. 


IA Es. period of time when microcomputers are 
reasonably priced, the US Navy could use these 
computers for effective training of personnel using 
Navy tailored programs. 


2. By using ICAI programs to train personnel, uncountable 
man hours in lecturing and teaching can be saved by 
supervisors. 


See ctive “damage Control casualty training can. be 
conducted on computers at times when a ship s schedule 
can t support actual casualty drills. 


4. This program, vocen Conducts training. on fires,' 18 
on one of many types of Sasa ty training Chigass 
conducted on ships. As demonstrated by this program, 
other computer rograms could be fievelopedamtot 
casualty training for engineering, weapons, nuclear 

ower, medical emergencies, and almost all other 
echnical areas where casualties could occur. 


5. The Naval Education and Training Command could acquire 
and make available ICAI programs to aid in the Navv s 
personnel Qualification be) Program which 
requires extensive knowledge in The operations and 
Casualty control of each watchstation. 
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APPENDING: 


DEMONSTRATION OF COMPLEX FIRE SIMULATION 


Steve, please enter the time of day(0001-2400): 1000. 


Thank You. Steve, if you are not familiar with my operation, request 
HELP, otherwise choose an area of Operations and/or Casualty 

Control that you’d like to challenge me in! 

1. HELP 

2. Individual Equipment Operations and Basic Damage Control Actions 
3. Individual Complex Damage Control Actions 

4. Complex Fire Simulation 


Enter a 1.. 2.. 3.. or 4. for desired category: 4. 


Steve, please enter vour abilitv level as follows: 

1. Beginner. 2. Advanced. 3. Expert. for this categorv. 
Enter a 1., 2.. or 3. for level: 

is-24 | 

GOOD LUCK! 


[next screen display | 
DING DING DING DING DING 
FIRE FIRE FIRE FIRE 
FIRE IN ENGINEERING STOREROOM , COMPARTMENT 1-22-1-A 


AWAY THE REPAIR PARTY FIRE TEAM AWAY! 


Steve , you are now the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, indicate your most important. 


or next action to be completed. 


. Extinguish all the fires. 

. Set a Reflash Watch. 

. Set fire boundaries. 

. Approach the fire. 

. Deenergize the space. 

. Get to the scene equipped and ready to go. 


CO) Ot A WH N = 


~] 


-HELE 
8. QUIT 
p 
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next screen display 
steve. BEFORE vou can perform the action: 
Remove all fires. 


YOU MUST FIRST perform the action: 
Isolate the fire. 


OTHERWISE 

the time and men and equipment you spend trying to remove the fires in 
one location will be wasted because the fire will continue to spread to 
new spaces until it is isolated. 


(Enter a "c." to continue. )c. 


next screen display 
STUDY AND LEARN the following information to help vou next time 
you have a similar situation. 
Below is a breakdown of the specific sub-actions. which make up the action: 
Isolate the fire. 


1. Get to the scene equipped and ready to go. 
2. Deenergize the space. 
3. Set fire boundaries. 


Do you want more breakdowns of these sub-actions? 
INDICATE WHICH SUB-ACTIONS USING FORMAT "[#,#)." 
otherwise ENTER "c." to continue. 
: alot. 
‘next screen display 

*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions. which make up the action: 
Isolate the fire. 


1. Get to the scene equipped and ready to go. 
2. Deenergize the space. 
3. Set fire boundaries. 


*** NEW SUB ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Get to the scene equipped and ready to go. 


. Get the fire team dressed. 

. Get the fire team to the scene. 

. Take charge of the scene. 

. Establish phone commuaications with 
the Repair Locker. 

. Charge the fire hoses. 


am C0 N 14 


qt 


81 


Do vou want more breakdowns of these sub-actions? 

INDICATE WHICH SUB-ACTIONS USING ORE a 
otherwise ENTER "c." to continue. 

oleae 


Next screen display 
*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Get to the scene equipped and ready to go. 


. Get the fire team dressed. 

. Get the fire team to the scene. 

. Take charge of the scene. 

. Establish phone communications with 
the Repair Locker. 

. Charge the fire hoses. 


md Wh 14 
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*** NEW SUB ACTION BREAKDOWN *** 


Below is a breakdown of the specific sub-actions, which make up the action: 
Get the fire team dressed. 


1. Dress the fire team in Battle Dress. 
2. Dress the fire team in OBA’s. 
3. Equip the fire team with fire fighting equipment. 


Do you want more breakdowns of these sub-actions? 
INDICATE WHICH SUB-ACTIONS USING FORMAT "'#,21." 
otherwise ENTER "c." to continue. 
Lee: 
¡next screen display. 

*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions. which make up the action: 
Get the fire team dressed. 


1. Dress the fire team in Battle Dress. 
2. Dress the fire team in OBA’s. 
3. Equip the fire team with fire fighting equipment. 


*** NEW SUB ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Dress the fire team in Battle Dress. 


1. Get personnel into long sleeve shirts. 

2. Get personnel to button up shirts at the 
neck and wrists. 

3. Get personnel to place their pants legs 
into their stockings. 
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Do you want more breakdowns of these sub-actions' 

INDICATE WHICH SUB-ACTIONS USING FORMAT "+= =." 
otherwise ENTER "c." to continue. 

mc. 


Enter "c." to continue: c. 


next screen display 
*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions. which make up the action: 
Get the fire team dressed. 


1. Dress the fire team in Battle Dress. 
2. Dress the fire team in OBA's. 
3. Equip the fire team with fire fighting equipment. 


*** NEW SUB ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Dress the fire team in OBA’s. 


1. Have personnel get OBA’s out of the 
Repair Locker. 
2. Have personnel check their OBA hoses 
for proper connections. 
3. Have personnel strap their OBA's 
firmly onto their bodies. 
4. Have personnel install their OBA cannisters. 
5. Have personnel don their OBA face pieces. 


Do you want more breakdowns of these sub-actions? 

INDICATE WHICH SUB-ACTIONS USING FORMAT "/#,#]." 
otherwise ENTER "c." to continue. 

: (4,5). 


¡next screen display! 
*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Dress the fire team in OBA ss. 


1. Have personnel get OBA’s out of the 
Repair Locker. 
2. Have personnel check their OBA hoses 
for proper connections. 
3. Have personnel strap their OBA's 
firmly onto their bodies. 
4. Have personnel install their OBA cannisters. 
5. Have personnel don their OBA face pieces. 
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nexi screen display 


at" NEW SUB ACTION DEDO a 


Below is a breakdown of the specific sub-actions. which make up the action: 
Have personnel install their OBA cannisters. 


1. Remove tear-off cap of canister by pulling tab backward and 

downward, exposing copper foil seal. Discard cap. 
WARNING 

When removing the candle cover. the lanvard must not be pulled so that 
the cotter pin is removed. Removal of the cotter pin fires the candle 
and starts generating oxygen. If this happens while the copper foil is 
intact, internal pressure in the cannister will build up causing the 
copper foil or cannister seam to rupture. 

2. Remove the canister candle cover by rotating swivel plate 180 
degrees, and push it down toward center of the canister, leaving cover 
dangling by the lanyard. Do not pull lanyard at this time. 

3. Insert the canister(with neck up and concave, or ribbed, 
side toward body) upward into the guard and breastplate assembly until 
the canister is firmly retained by the bail. The canister is now locked 
in standby position, with the copper foil seal still intact. 


Enter a "c." to continue. 


¡next screen display 
*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Dress the fire team in OBA's. 


1. Have personnel get OBA's out of the 
Repair Locker. 
2. Have personnel check their OBA hoses 
for proper connections. 
3. Have personnel strap their OBA’s 
firmly onto their bodies. 
4. Have personnel install their OBA cannisters. 
5. Have personnel don their OBA face pieces. 


Enter a ''c.'' to continue. 


Inext screen displav: 


*** NEW SUB ACTION BREAKDOWN *** 


Below is a breakdown of the specific sub-actions, which make up the action: 
Have personnel don their OBA face pieces. 
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1. Place head harness straps over front of face piece. 
2. Insert chin into chin stop of the face piece. 
removed user session lines 


Enter a "c." to continue. 


¡next screen display! 

*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Get to the scene equipped and ready to go. 

removed user session lines| 


| *** NEW SUB ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Take charge of the scene. 


1. Visually assess the status of the casualty 
control procedures in progress. 

2. Identify the senior person in charge at the scene. 

3. Relieve the senior person in charge at the scene. 


Do you want more breakdowns of these sub-actions? 

INDICATE WHICH SUB-ACTIONS USING FORMAT "¡4.4 |." 
otherwise ENTER "c." to continue. 

Bake i 


‘next screen display! 
*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Take charge of the scene. 


1. Visually assess the status of the casualty 
control procedures in progress. 

2. Identify the senior person in charge at the scene. 

3. Relieve the senior person in charge at the scene. 


*** NEW SUB ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Relieve the senior person in charge at the scene. 
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1. When ready to receive briefing from the man 
in charge state to him. 

"TI am ready to relieve vou." 

. Receive briefing from the man in charge. 
(Obtain who, what, when. where. and how 
information about the casualty if available.) 

3. When ready to take charge of the scene state, 

"I relieve you." 

4. Announce to all personnel at the scene that 

you are the man in charge. 


to 


Do you want more breakdowns of these sub-actions? 

INDICATE WHICH SUB-ACTIONS USING FORMAT "|#,#]." 
otherwise ENTER "c." to continue. . 

le) 


Enter "c." to continue: c. 


[next screen display] 
*** REMINDER OF PREVIOUS ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Isolate the fire. 


1. Get to the scene equipped and ready to go. 
2. Deenergize the space. — 
3. Set fire boundaries. | 


*** NEW SUB ACTION BREAKDOWN *** 
Below is a breakdown of the specific sub-actions, which make up the action: 
Set fire boundaries. 


1. Have Repair Locker locate on ship’s compartment 
drawings all adjacent spaces and all physical 
openings to the space including doors, 
ventilation ducts, and drains. 

. Send fire boundary teams to shut all physical 
openings to the space with the fire. 

. Send fire boundary teams to each adjacent 
space with portable fire equipment in order 
to verify the boundaries are containing the fire. 


nh 


Cy 


Do you want more breakdowns of these sub-actions? 
INDICATE WHICH SUB-ACTIONS USING FORMAT "{#,#]." 
otherwise ENTER "c." to continue. 
pone 
[removed user session lines) 
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next screen display 
Steve ‘s Score Level 
UE One 
Steve . vou are the " FIRE TEAM LEADER ." 


f . . ka 
¡removed user session lines 


FIRE TEAM LEADER, you MUST now DIRECT THE ACTIONS to complete the 
following TASK: Deenergize the space. 


FIRE TEAM LEADER, indicate your most important, 


or next action to be completed. 


. Store all equipment away in the Repair Locker. 

. Lead the fire team to the Repair Locker. 

. Choose and activate a drain method type. 

. Have Repair Locker locate on the ship's electrical 
drawings all circuit breakers which isolate 
electrical power to the space on fire. 

. Obtain a satisfactory second Oxygen Test. 

6. Send electrician to locate and open all circuit 

breakers which isolate electrical power to the 

space on fire. 


a 0 ND e= 
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T- HELP 
8. QUIT 
82, 


¡next screen display! 
Steve, BEFORE vou can perform the action: 
Put away the fire fighting equipment. 


YOU MUST FIRST perform the action: 


Dewater the space. 


OTHERWISE 
personnel will not have the equipment to properly dewater the space 
which may result in increased equipment water damage. 


(Enter a "c." to continue. )c. 


¡next screen display 
STUDY AND LEARN the following information to help you next time 
vou have a similar situation. 
Below is a breakdown of the specific sub-actions, which make up the action: 
Dewater the space. 
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i. Determine the amount of water in the space. 
2. Choose and activate a drain method type. 


Do you want more breakdowns of these sub-actions? 
INDICATE WHICH SUB-ACTIONS USING FORMAT "[#,#'." 
otherwise ENTER "c." to continue. 
E 
[removed user session lines. 


next screen display] 
Steve 's Score Level 
NA 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you receive the following report: 
The action: Send electrician to locate and open all circuit 
breakers which isolate electrical power to the 
space on fire. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 
The electrician has open all circuit breakers 
which provide power to the space. 


FIRE TEAM LEADER, you receive the following report: 
The action: Deenergize the space. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 


The space has not yet been deenergized. 


FIRE TEAM LEADER. indicate your most important, 


or next action to be completed. 


. Get to the scene equipped and ready to go. 
. Extinguish all the fires. 

. Approach the fire. 

. Set a Reflash Watch. 

. Deenergize the space. 

. Set fire boundaries. 


we CO RO — 
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. HELP 
8. QUIT 
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next screen display 
Steve 's Score Level 
SOS. TN 
Steve . vou are the " FIRE TEAM LEADER ." 


removed user session lines 


FIRE TEAM LEADER, you THEN receive the following report: 


All fire boundaries have been set. 


FIRE TEAM LEADER. you THEN receive the following report: 
A man has broken a finger while shutting the entrance 
hatch door to the space with a fire. 


FIRE TEAM LEADER. indicate your most important, 


or next action to be completed. 


. Extinguish all the fires. 

. Obtain a satisfactory first Oxygen Test. 

. Set a Reflash Watch. 

. Choose and activate a drain method type. 
. Take care of the injured person. 

. Replace the injured person. 


Oud WLW be 
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-HELP 
8. QUIT 
ee: 


¡next screen display 
Steve, your choice of: 
Obtain a satisfactory first Oxygen Test. 


has nothing to do with the current most important 
action to be performed. The LAST REPORT: 

A man has broken a finger while shutting the entrance 
hatch door to the space with a fire. 


should help you decide what to do next. 


(Enter a "c.' to continue.)c. 
removed user session lines 


next screen display 
Steve ’s Score Level 
12 of 15 80% 
Steve , you are the " FIRE TEAM LEADER ." 
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FIRE TEAM LEADER. you receive the following report: 
The action: Replace tne injured person. 
has been reported completed. 


FIRE TEAM LEADER. you THEN receive the following report: 


A relief hasn't been located yet for the injured person. 


FIRE TEAM LEADER. indicate your most important, 


or next action to be completed. 


. Extinguish all the fires. 

. Get the oxygen testing equipment. 
. Take care of the injured person. 

. Replace the injured person. 

. Set fire boundaries. 


. Secure the Reflash Watch. 


da WwW N — 
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SELT 
8. QUIT 
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¡next screen display] 
Steve `s Score Level 
15 of 18 83% 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you MUST now DIRECT THE ACTIONS to complete the 
following TASK: Approach the fire. 


FIRE TEAM LEADER. indicate your most important, 
or next action to be completed. 


1. Crack open the space boundary. 
2. Activate both working and backup hoses 
into the space. 
. Completely open the access door. 
. Store all equipment away in the Repair Locker. 
. Deenergize the space. 
Obtain a satisfactory first Oxygen Test. 


tm CO 
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7. HELP 
“QUIT 
de 
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¡next screen display] 
Steve. you YOU HAVE ALREADY COMPLETED the action: 


Deenergize the space. 
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arena "c." to continue. )c. 


removed user session lines 


next screen display 
Steve 's Score .Level 
19 of 23 82% 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you receive the following report: 
The action: Enter the space with both the working 

and backup hoses. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 
The space has been entered with both 
the working and backup hoses. 


FIRE TEAM LEADER, you receive the following report: 
The action: Approach the fire. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 
The fire team has opened the space and is 
approaching the fire. 


FIRE TEAM LEADER, indicate your most important, 


or next action to be completed. 


. Verify all fires are out. 

. Extinguish all the fires. 

. Set a Reflash Watch. 

. Approach the fire. 

. Perform explosive gas tests. 
. Set fire boundaries. 


O Ut Aa UD NN m= 


T. HBHP 
8. QUIT 
22. 


¡next screen display 
Steve ’s Score Level 
20 of 24 83% 
Steve . you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you MUST now DIRECT THE ACTIONS to complete the 
following TASK: Extinguish all the fires. 
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next screen display 


* * * KNOWLEDGE TEST PROGRAM” >`” 


Steve. you wil] be shown various sequences of 
Operational steps to perform the Task: 


Extinguish all the fires. 


The reference for this task’s sequence of operational steps is the 


BASIC MILITARY REQUIREMENTS . NAVEDTRA 10054-El, p.11-10 


If the sequence is correct, you should enter a "ves." 

otherwise a "no." if its incorrect. If your answer is incorrect, 
you'll be shown the correct sequence of steps and given 0 points 
for this test. If your answer is correct you'll be given 1 point 
for this test. 


Enter a ''c.' to continue. 


¡next screen display 
Steve, are the following steps the correct sequence to 
perform the task: 
Extinguish all the fires. 


. Activate both hoses into the space. 

. Cover all fires with water. 

. Use low velocity fog, then only if necessary 

. Use high velocity fog, then only if necessary 

. Use straight solid stream of water. REMEMBER EVERY GALLON 

OF WATER PUT ON A FIRE MUST BE PUMPED OVERBOARD OR DISPOSED 
OF IN SOME MANNER. 


A O N e 


or "no. ves. 


Enter a "yes.' 
Steve, your answer is correct. 


Enter a "c." to continue. 
removed user session lines. 
Steve 's Score Level 
24 of 28 85% 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you receive the following report: 


The action: Verify all fires are out. 
has been reported completed. 
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FIRE TEAM LEADER. you THEN receive the following report: 
small signs of new smoke are still being investigated 
in the space. 


FIRE TEAM LEADER, indicate your most important. 


or next action to be completed. 


. Set a Reflash Watch. 

. Perform explosive gas tests. 

. Verify all fires are out. 

. Desmoke the space. 

. Extinguish all the fires. 

. Get the oxygen testing equipment. 


m OC Ne 
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i HELP 
8. QUIT 
eas 


¡next screen display 
Steve ’s Score Level 
25 of 29 86% 
Steve , you are the " FIRE TEAM LEADER ." 


removed user session lines, 


FIRE TEAM LEADER, you THEN receive the following report: 


The overhaul equipment rake has broken. 


FIRE TEAM LEADER, indicate your most important, 
or next action to be completed. 


. Have second team member check for proper operation of the equipment. 
. Store all equipment away in the Repair Locker. 
. Perform explosive gas tests. 
. Have fire team member recheck proper operation of 

malfunctioning equipment. 
. If equipment is still malfunctioning. check local area for replacement. 
. Dismiss the fire team. 
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¡next screen display. 
Steve ’s Score Level 
26 of 30 86% 
Steve , you are the " FIRE TEAM LEADER ." 
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FIRE TEAM LEADER. vou receive the following report: 

The action: Have fire team member recheck proper operation of 
malfunctioning equipment. 

has been reported completed. 


FIRE TEAM LEADER, vou THEN receive the following report: 
The equipment is definitely not working correctly. 
¡removed user session lines 


¡next screen display] 
Steve ’s Score Level 
32 of 36 88% 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you receive the following report: 

The action: Request from Repair Locker replacement equipment or an alternative 
plan to correct the malfunctioning equipment situation. 

has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 
A replacement piece of equipment has been located is at the scene. and the 
Repair Locker wants you to continue on your present plan of attack. 


FIRE TEAM LEADER, indicate your most important, 
or next action to be completed. 
¡removed user session lines] 


[next screen display! 
Steve 's Score Level 
37 of 41 90% 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you receive the following report: 
The action: Sample the space, which had the fire, 

for explosive gases. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 


The explosive gas tester wasn’t operated properly during the last test sample. 


FIRE TEAM LEADER, indicate your most important, 
or next action to be completed. 
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l. Sample the space. which had the fire. 
for explosive gases. 
. Dismiss the fire team. 
. Get explosive gas tester. 
. Set a Reflash Watch. 
. Obtain a satisfactory second Oxygen Test. 
. Have the explosive gas tester tested. 
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¡next screen display! 
Steve ‘s Score Level 
38 of 42 90% 
Steve , vou are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, you MUST now DIRECT THE ACTIONS to complete the 
following TASK: Sample the space. which had the fire. 
for explosive gases. 


Enter a ''c.'' to continue. 


¡next screen display! 


* * * KNOWLEDGE TEST PROGRAM * * * 


Steve, you will be shown various sequences of 
operational steps to perform the Task: 


Sample the space. which had the fire, 
for explosive gases. 


The reference for this task’s sequence of operational steps is the 
COMBUSTIBLE GAS INDICATORS, NAVEDTRA 465-08-00-82, pp. 4-5. 


‘removed user session lines) 


¡next screen display. 
Steve 's Score Level 
40 of 44 90% 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER, vou receive the following report: 
The action: Perform explosive gas tests. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 


Explosive Gas Tests indicate negative explosive gas. 
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FIRE TEAM LEADER. vou THEN receive the following report: 
The pre-use test of the tester rndicated explosive gases 
in outside the ship fresh air. 


FIRE TEAM LEADER. indicate your most important. 


or next action to be completed. 


. Have second team member check for proper operation of the equipment. 
. Desmoke the space. | 
. If equipment is still malfunctioning, check local area for replacement. 
. Get the oxygen testing equipment. 

. Have fire team member recheck proper operation of 

malfunctioning equipment. 

. Test the oxygen test equipment. 

. HELP 

. QUIT 
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next screen display! 
Steve. your choice of: 
Get the oxygen testing equipment. 


has nothing to do with the current most important 
action to be performed. The LAST REPORT: 

The pre-use test of the tester indicated explosive gases 
in outside the ship fresh air. 


should help you decide what to do next. 
¡removed user session lines 


YOUR LAST REPORT WAS: 
The pre-use test of the tester indicated explosive gases 
in outside the ship fresh air. 


FIRE TEAM LEADER. indicate your most important, 


or next action to be completed. 


. Get the oxygen testing equipment. 
. Test the oxygen test equipment. 
. Have fire team member recheck proper operation of 
malfunctioning equipment. 
. Desmoke the space. 
. If equipment is still malfunctioning, check local area for replacement. 
. Have second team member check for proper operation of the equipment. 


_ HELP 
. QUIT 
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| next screen display 
Steve. you have FAILED TO REALIZE that a REFLASH. 
Beige Neve INITRY or EQUIPMENT FAILURE CASUALTY has just occurred 
or you've taken the WRONG IMMEDIATE ACTION! 


You MUST take the CORRECT IMMEDIATE ACTIONS in the CORRECT ORDER 
to CONTROL and RECOVER from this CASUALTY. 


removed user session lines 


¡next screen display. 
Steve `s Score Level 
40 of 46 86% 
Steve , you are the " FIRE TEAM LEADER ." 


YOUR LAST REPORT WAS: 
The pre-use test of the tester indicated explosive gases 
in outside the ship fresh air. 


FIRE TEAM LEADER. indicate your most important, 


or next action to be completed. 


. Desmoke the space. 

Get the oxygen testing equipment. 

Test the oxygen test equipment. 

. Have second team member check for proper operation of the equipment. 
. If equipment is still malfunctioning, check local area for replacement. 

. Have fire team member recheck proper operation of 

malfunctioning equipment. 
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8. QUIT 
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next screen display 


FINAL GRADE OF PERFORMANCE 
Congratulations Steve you've survived! 


Remember there's always room for improvement in Damage Control 
Casualty Training. Your life. your shipmate's. and your 

ship’s survival may someday depend on your KNOWLEDGE as a 
MAN IN CHARGE of a casualty. The following is a report of 


vour performance: 
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Casualty Task Points Tota! Percent Grade 
Overall Score 41 47 87 


Deenergize the space. 
Pts = 3 Total = 4 Percent Grade = 


=l 


QU 


Set fire boundaries. 
Pts = 4 Total = 4 Percent Grade = 100 


Injured Person Casualty. 
Pts = 3 Total = 4 (Percent Grage — 1/5 


Approach the fire. : 
Pts = 4 Total = 5 Percent Grade 


l 


80 


Extinguish all the fires. 
Pts = 1 Total = 1 Percent Grade 


l 


100 


Perform explosive gas tests. 
Pts= 5 Total = 5 Percent Grade — 100 


Sample the space. which had the fire for explosive gases. 
Pts = 1 Total = 1 Percent Grade = 100 


Main Fire 
Pts = 12 Total = ds Percent made = 92 


Broken Equipment Casualty. 
Pts= 7 Total = 9 Percent Grade = 77 


Enter a °c.’ to continue. 


¡next screen display 
FOLLOW ON TRAINING OPPORTUNITIES 
For further training on the types of damage control actions or 
equipment operations you just directed : 
Enter a 1. To Quit 
2. Previous Fire Casualty Operations Training 
Ue 
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APPENDIX B 


EXPERT LEVEL DEMONSTRATION OF COMPLEX FIRE SIMULATION 


Steve, please enter the time of day(0001-2400): 1100. 


Thank You. Steve, if you are not familiar with my operation. request 
HELP, otherwise choose an area of Operations and/or Casualty 

Control that you’d like to challenge me in! 

1 MELP 

Individual Equipment Operations and Basic Damage Control Actions 
Individual Complex Damage Control Actions 

Complex Fire Simulation 


Enter a 1.. 2., 3.. or 4. for desired category: 4. 


Steve, please enter your ability level as follows: 

1. Beginner, 2. Advanced. 3. Expert, for this category. 
Enter a 1.. 2., or 3. for level: 

fat 

GOOD LUCK! 


‘next screen display) 
DING DING DING DING DING 
FIRE FIRE FIRE FIRE 
FIRE IN ’E* DIVISION BERTHING , COMPARTMENT 1- 34-1-L 


AWAY THE REPAIR PARY FIRE TEAM AWAY! 
Steve , you are now the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER. indicate your most important, 


or next action to be completed. 


. Extinguish all the fires. 

. Set a Reflash Watch. 

. Verify all fires are out. 

. Approach the fire. 

. Desmoke the space. 

. Test the oxygen test equipment. 

. Get to the scene equipped and ready to go. 
. Perform explosive gas tests. 

9. Deenergize the space. 

10. Obtain a satisfactory first Oxygen Test. 
11. Set fire boundaries. 

12. Get the oxygen testing equipment. 


-~ O OA W N = 


00 


99 


IE 
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next screen display 
Steve. BEFORE you can perform the actior::: 
Remove all fires. 


YOU MUST FIRST perform the action: 
Isolate the fire. 


OTHERWISE 

the time and men and equipment you spend trying to remove the fires in 
one location will be wasted because the fire will continue to spread to 
new spaces until it is isolated. 


(Enter a "c." to continue. )c. 


¡next screen display] 
STUDY AND LEARN the following information to help you next time 
you have a similar situation. 
Below is a breakdown of the specific sub-actions, which make up the action: 
Isolate the fire. 


1. Get to the scene equipped and ready to go. 
2. Deenergize the space. 
3. Set fire boundaries. 


Do you want more breakdowns of these sub-actions? 
INDICATE WHICH SUB-ACTIONS USING FORMAT "[#,#]." 
otherwise ENTER "c." to continue. 
Pac. 
¡removed user session lines 


‘next screen display| 
Steve ’s Score Level 
0 of 1 0% 
Steve , you are the " FIRE TEAM LEADER." 


YOUR LAST REPORT WAS: 


The ship has been informed of the location of the fire. 


FIRE TEAM LEADER, indicate your most important. 
or next action to be completed. 
[removed user session lines) 
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11. Set fire boundaries. 
12. Desmoke the space. 
13. HELP 

Ti. QUIT 

Pil. 


next screen display. 
Steve. BEFORE you can perform the action: 
Set fire boundaries. 


YOU MUST FIRST perform the action: 


Deenergize the space. 


OTHERWISE 
if the fire’s source is electrical, it will continue to help the fire 
grow in intensity and if the fire’s source wasn’t electrical, 
electrical cabling in the fire space will soon breakdown due to the heat 
and cause new fires. 
removed user session lines 


¡next screen display) 
Steve ‘s Score Level 
Oser 2 0% 
Steve . vou are the " FIRE TEAM LEADER ." 


MOUR LAST REPORT W AS: 
The ship has been informed of the location of the fire. 


FIRE TEAM LEADER. indicate your most important. 
or next action to be completed. 
removed user session lines 
10. Get to the scene equipped and ready to go. 
11. Obtain a satisfactory first Oxygen Test. 
12. Deenergize the space. 


13. HELP 
14. QUIT 
9: 12: 


next screen displav) 
Steve, BEFORE vou can perform the action: 


Deenergize the space. 


VOU MUST FIRST perform the action: 
Get to the scene equipped and ready to go. 
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OTHERWISE 

vour personnel may deenergize the wrong spaces or risk personnel injury 
by not using proper safety precautions such as rubber gloves while 
operating breakers or fuses. 


(Enter a "c." to continue. )c. 


next screen display: 
STUDY AND LEARN the following information to help you next time 
you have a similar situation. 
Below is a breakdown of the specific sub-actions, which make up the action: 
Get to the scene equipped and ready to go. 


. Get the fire team dressed. 
. Get the fire team to the scene. 
. Take charge of the scene. 
. Establish phone communications with 
the Repair Locker. 
. Charge the fire hoses. 
¡removed user session lines 


mem Whe 


QU 


¡next screen display 
Steve ‘s Score Level 
0 of 3 0% 
Steve , you are the " FIRE TEAM LEADER ." 


YOUR LAST REPORT WAS: 
The ship has been informed of the location of the fire. 


FIRE TEAM LEADER. indicate your most important, 
or next action to be completed. 
removed user session lines 
10. Get to the scene equipped and ready to go. 
11. Verify all fires are out. 
12. Get the oxygen testing equipment. 


13- HELP 
14. QUIT 
re TO: 


inext screen display 
Steve `s Score Level 
| of 4 25% 
Steve . you are the " FIRE TEAM LEADER ." 
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FIRE TEAM LEADER. vou receive the following report: 
The action: Get to the scene equipped and ready to go. 
has been reported completed. 


FIRE TEAM LEADER. vou THEN receive the following report: 


The fire team is on the scene and ready to go. 


FIRE TEAM LEADER. indicate your most important, 
or next action to be completed. 
¡removed user session lines! 
. Obtain a satisfactory first Oxygen Test. 
. Approach the fire. 
9. Desmoke the space. : 
10. Get to the scene equipped and ready to go. 
11. Extinguish all the fires. 
12. Verify all fires are out. 


00 HI 


13. HELP 
14. QUIT 
t: 10. 


‘next screen display! 
Steve, the LAST REPORT: 


The fire team is on the scene and ready to go. 


SHOULD HAVE indicated to you that the action: 
Get to the scene equipped and ready to go. 


has JUST BEEN COMPLETED. 


¡removed user session lines 


¡next screen display. 
Steve `s Score Level 
swf 7 au 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER. you receive the following report: 
The action: Have Repair Locker locate on the ship's electrical 
drawings all circuit breakers which isolate 
electrical power to the space on fire. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 


The ship's drawings haven't been located yet. 
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FIRE TEAM LEADER. indicate vour most important. 
or next action to be completed. 


1. Verify all fires are out. 

2. Get to the scene equipped and ready to go. 

3. Dismiss the fire team. 

4. Have Repair Locker locate on the ship’s electrical 
drawings all circuit breakers which isolate 
electrical power to the space on fire. 

5. Determine the amount of water in the space. 

6. Send electrician to locate and open all circuit 
breakers which isolate electrical power to the 
space on fire. 

‘removed user session lines, 
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¡next screen display. 


Steve, your PREVIOUS ACTION: 


Have Repair Locker locate on the ship's electrical 
drawings all circuit breakers which isolate 
electrical power to the space on fire. 


hasn’t been completed yet. You SHOULD 
HAVE REALIZED THIS by the LAST REPORT you received: 


The ship’s drawings haven’t been located yet. 
Enter a "c." to continue. 


¡next screen display 


*** NEW SUB ACTION BREAKDOWN *** 


Below is a breakdown of the specific sub-actions. which make up the action: 
Have Repair Locker locate on the ship’s electrical 
drawings all circuit breakers which isolate 
electrical power to the space on fire. 
removed user session lines| 


next screen display | 
Steve ’s Score Level 
5 of 11 45% 
Steve , you are the " FIRE TEAM LEADER ." 
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FIRE TEAM LEADER. vou receive the following report: 
The action: Send electrician to locate and open all circuit 
breakers which isolate electrical power to the 
space on fire. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 
The electrician has open all circuit breakers 
which provide power to the space. 


FIRE TEAM LEADER. you receive the following report: 
The action: Deenergize the space. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 


The space has not yet been deenergized. 


FIRE TEAM LEADER, indicate vour most important, 
or next action to be completed. 
‘removed user session lines 
10.Deenergize the space. 
11.Set a Reflash Watch. 
12.Extinguish all the fires. 


ISE LP 
14. QUIT 
: MOL 

removed user session lines 

next screen display 
FINAL GRADE OF PERFORMANCE 

removed user session lines 
Casualty Task Points Total Percent Grade 
Overall Score 7 13 53 


Have Repair Locker locate on the ship’s electrical, drawings all circuit 
breakers which isolate. electrical power to the space on fire. 
Pts= 0 Total = 1 Percent Grade = 0 


Deenergize the space. 
Pts = 3 Total = 4 Percent Grade = 


7 


5 


Main Fire 
Pts = 4 Total = 8 Percent Grade = 50 
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Enter a 'c.. to continue. 


next screen display 
FOLLOW ON TRAINING OPPORTUNITIES 
For further training on the types of: damage control actions or 
equipment operations you just directed : 
Enter a 1. To Quit 
2. Previous Fire Casualty Operations Training 
oes 


¡next screen display. 


O LOWS TRAINING REVIEW * * * 


Steve, you will be retested on the tasks which you were 
just tested on. I’ve taken the liberty of ordering the tasks 
with your best first, then your worst second, then your second 
best third, then your second worst fourth and so on. 
I think you’ll enjoy this order of retraining the best. 

GOOD LUCK! 


Enter a "c." to continue. 


Inext screen display 
Steve, your task will be: 
Deenergize the space. 
Your previous performance grade was 75 for this task. 
¡removed user session lines! 


¡next screen display! 
Steve 's Score Level 
2 of 2 100% 
Steve , you are the " FIRE TEAM LEADER ." 
FIRE TEAM LEADER, you receive the following report: 
The action: Send electrician to locate and open all circuit 
breakers which isolate electrical power to the 
space on fire. 
has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 


The electrician has open all circuit breakers 
which provide power to the space. 


THIS COMPLETES YOUR TEST OF THE DAMAGE CONTROL ACTION: 


Deenergize the space. 


106 


tt 


Enter a "c." to continue. 


next screen display 
Steve. vour task will be: 
Have Repair Locker locate on the ship's electrical. drawings all 


circuit breakers which isolate, electrical power to the space on fire. 


Your previous performance grade was 0 for this task. 
¡removed user session lines! 


¡next screen display] 


THANK YOU FOR USING THE 
"DAMAGE CONTROL" 
"FIRE TEAM LEADER" 


LEARNING CENTER 


For more training START THE PROGRAM OVER. 
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APPENDIX C 


DEMONSTRATION OF FIRES SECONDARY MODES Or Clie. Man. 


WELCOME TO THE 
"DAMAGE CONTROL" 
"FIRE TEAM LEADER" 


LEARNING CENTER 


PROLOG requires all input to be followed by a period("."). 
BEGINNER TEST RUN SCREEN DISPLAY 


Welcome. I am an EXPERT in FIRE FIGHTING and DAMAGE CONTROL! 
I am ready to challenge your knowledge as a fire team scene 
leader or supervisor! Please enter your NAME: 'Steve'. 


Steve, please enter the time of day(0001-2400): 0930. 


Thank You. Steve, if you are not familiar with my operation, request 
HELP. otherwise choose an area of Operations and/or Casualty 

Control that you’d like to challenge me in! 

1. HELP 

2. Individual Equipment Operations and Basic Damage Control Actions 
3. Individual Complex Damage Control Actions 

4. Complex Fire Simulation 


Enter a 1.. 2.. 3.. or 4. for desired category: 2. 
; gory 


Steve, please enter your ability level as follows: 

1. Beginner. 2. Advanced. 3. Expert, for this category. 
Enter a 1., 2.. or 3. for level: 

Ie 

GOOD LUCK! 


¡next screen display 
* * * Equipment Operation Tests * * * 


Steve, you will be shown a list of equipment related operations 
and asked to enter which operations you want to review and be tested 
on. A running score of your performance on your chosen equipment 


operations will be displayed. -- GOOD LUCK! 
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next screen display 
1. Establish phone communications with 
the Repair Locker. 

. Charge the fire hoses. 

3. Have Repair Locker locate on the ship's electrical 
drawings all circuit breakers which isolate 
electrical power to the space on fire. 

4. Send fire boundary teams to each adjacent 
space with portable fire equipment in order 
to verify the boundaries are containing the fire. 

3. Have personnel check their OBA hoses 
for proper connections. 

6. Have personnel strap their OBA’s 

firmly onto their bodies. 

. Have personnel install their OBA cannisters. 

. Have personnel don their OBA face pieces. 

. Identify the deck. frame. centerline 

relationship. and function of the space. 

10. Determine the route to the scene. 

11. Activate both working and backup hoses 
into the space. 

12. Extinguish all the fires. 

13. Set a Reflash Watch. 

14. Have the explosive gas tester tested. 

15. Sample the space. which had the fire, 
for explosive gases. 

16. Choose a desmoke method. 

17. Have a smoke removal path established. 

18. Test the oxygen test equipment. 

19. Obtain a satisfactory first Oxygen Test. 

20. Obtain a satisfactory second Oxygen Test. 

21. Determine the amount of water in the space. 

22. Choose and activate a drain method type. 

23. Conduct a debriefing of the fire casualty 
with the fire team. 

24. Remove the injured person to a safe location. 

25. Have basic first aid administered to the injured person. 


bo 


KO 00 


Steve, INDICATE WHICH OPERATIONS USING FORMAT "[4,4)." 
le. 11.3,41. 
|: 118,12.25). 
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next screen display 


*** KNOWLEDGE TEST PROG wine 


Steve. vou will be shown various sequences of 
operational steps to perform the Task: 


Test the oxygen test equipment. 


The reference for this task’s sequence of operational steps is the 


FLAME SAFETY LAMP, NAVEDTRA 465-08-00-82, pp. 9-10. 


If the sequence is correct. you should enter a "yes." 

otherwise a "no." if its incorrect. If your answer is incorrect, 
you'll be shown the correct sequence of steps and given 0 points 
for this test. If your answer is correct you'll be given 1 point 
for this test. 


Enter a "c." to continue. 


inext screen display | 
Steve. are the following steps the correct sequence to 
perform the task: 
Test the oxygen test equipment. 
¡removed user session lines! 


[next screen display! 
Steve, are the following steps the correct sequence to 
perform the task: 
Test the oxygen test equipment. 


1. Blow against the glass and gaskets to test the lamp for leakage. 
Leakage will cause the flame to flicker. 

2. Pull the knob down and adjust the flame to approximately 
3/8 inch in height. Allow the flame to burn about 5 minutes to reach 
1ts normal operating temperature. 

3. Push on the relighter handle(igniter) and slide it up as 
far as 1t will go. Turn the relighter handle and ignite the wick. 

4. Turn up the wick using the wick adjuster. 


Enter a "yes." or "no.": yes. 


Steve, you are incorrect. the above sequence 
is not correct! Below is the correct sequence; 


STUDY AND LEARN it before you continue. 
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1. Turn up the wick using the wick adjuster. 

. Push on the relighter handle(igniter) and slide it up as 

far as it will go. Turn the relighter handle and ignite the wick. 

. Pull the knob down and adjust the flame to approximately 

3/8 inch in height. Allow the flame to burn about 5 minutes to reach 

its normal operating temperature. 

4. Blow against the glass and gaskets to test the lamp for leakage. 
Leakage will cause the flame to flicker. 


to 


Co 


Enter a "c." to continue. 


‘next screen display! 
Steve s Score Level 
Oof 1 0% 


EA KNOWLEDGE TEST PROGRAM * * * 


Steve, you will be shown various sequences of 
operational steps to perform the Task: 


Extinguish all the fires. 


The reference for this task’s sequence of operational steps is the 


BASIC MILITARY REQUIREMENTS . NAVEDTRA 10054-E1. p.11-10 


¡removed user session lines 


Steve. are the following steps the correct sequence to 
perform the task: 
Extinguish all the fires. 


. Activate both hoses into the space. 

. Cover all fires with water. 

. Use low velocity fog, then only if necessary 

. Use high velocity fog. then only if necessary 

. Use straight solid stream of water. REMEMBER EVERY GALLON 
OF WATER PUT ON A FIRE MUST BE PUMPED OVERBOARD OR 
DISPOSED OF IN SOME MANNER. 


N = 


Ot A Co 


Enter a "yes." or "no.": no. 


Steve. you are incorrect, the above sequence is correct! 


STUDY AND LEARN it before vou continue. 


Enter a "c." to continue. 
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next Screen display 
“** KNOW LEDGE Ria ih a. a 
Steve. you will be shown a review of 
important knowledge required in the performance of Task: 


Have basic first aid administered to the injured person. 


STUDY AND LEARN THIS INFORMATION and for further guidance refer 
to reference: 
BASIC MILITARY REQUIREMENTS, NAVEDTRA 10054-El, pp. 18-1.2. 


you will not ve graded on this review. 
Enter a "c." to continue. 


¡next screen display 
GENERAL FIRST AID RULES 
Although each case involving injury or sickness presents its own special 
problems, there are some general rules, given here. that apply to practically 
all situations. Become familiar with these basic rules before you go on to 
learn first aid treatment for specific types of injuries. 
1. Keep the victim lying down. head level with the body. until 
you have found out what kind of injury has occurred and how serious it is. 
If the victim shows one of the following difficulties, however, follow the 
rule given for that specific problem: 
¡removed user session lines: 
8. Keep the injured person comfortably warm-warm enough to maintain 
normal body temperature. 
removed user session lines: 


¡next screen display. 
Steve, please enter the time of day(0001-2400): 0945. 


Thank You. Steve. if you are not familiar with my operation, request 
HELP, otherwise choose an area of Operations and/or Casualty 

Control that you'd like to challenge me in! 

1. HELP 

2. Individual Equipment Operations and Basic Damage Control Actions 
3. Individual Complex Damage Control Actions 

4. Complex Fire Simulation 


Enter a 1., 2., 3.. or 4. for desired category: 3. 


Steve, please enter your ability level as follows: 

1. Beginner. 2. Advanced. 3. Expert, for this category. 
Enter a 1., 2., or 3. for level: 

e UN 

GOOD LUCK! 
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next screen display 


oe Oee GE CONTROL ACTION TESTS * 


Steve. you will be shown a list of damage control related actions 


an 


on. 


d asked to enter which actions you want to review and be tested 
A running score of your performance on your chosen damage control 


actions will be displayed. -- GOOD LUCK! 


Enter a "c." to continue. 


“I Oo fh WN = 


KO 00 


next screen display] 


. Injured Person Casualty. 
. Broken Equipment Casualty. 
. Get to the scene equipped and ready to go. 


Deenergize the space. : 


. Set fire boundaries. 


Get the fire team dressed. 


. Get the fire team to the scene. 
. Take charge of the scene. 
. Send fire boundarv teams to shut all physical 


openings to the space with the fire. 


10 
11 
19% 
13 
14 


ko. 
16. 
I 
18. 
19. 
20. 
21. 
22. 
2 8. 
24. 
29: 


. Dress the fire team in Battle Dress. 
. Dress the fire team in OBA’s. 
. Equip the fire team with fire fighting equipment. 
. Have personnel put their helmets on. 
. Determine the required fire fighting 
equipment for personnel. 

Locate the fire. 

Relieve the senior person in charge at the scene. 
Approach the fire. 

Crack open the space boundary. 

Verify all fires are out. 

Perform explosive gas tests. 

Desmoke the space. 

Store all equipment away in the Repair Locker. 
Secure the Reflash Watch. 

Take care of the injured person. 

Have medical aid given to the injured person. 


Steve. INDICATE WHICH ACTIONS USING FORMAT "{#.#!." 


Je. 


fl aed 


: 123.3.8.201. 
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next screen display 


= * * DAMAGE CONTROEMGAIO fis] = 


Steve. vou may now direct the actions to 
properly execute the action: 


Secure the Reflash Watch. 


Your score for this task will be displayed as you carry 


out the actions. -- GOOD LUCK! 
Enter a "c." to continue. 
¡next screen display] 


FIRE TEAM LEADER. indicate .your most important. 


or next action to be completed. 


p= 


. Check that the required Reflash Watch 

on station time has elapsed. 

. Have the Reflash Watch put his equipment 

away in the Repair Locker. 

. Get the Enginneer’s or his designated representative's 
permission to secure the Reflash Watch. 


bo 


ew 


ATHELEP 
.QUIT. 
ae 


QO 


[next screen display] 
Steve 's Score Level 
1 of 1 100% 
Steve , you are the" FIRE TEAM LEADER ." 


removed user session lines 


[next screen display] 
Steve 's Score Level 
2 of 2 100% 
Steve , you are the ' FIRE TEAM LEADER ." 


FIRE TEAM LEADER. you receive the following report: 

The action: Get the Enginneer’s or his designated representative’s 
permission to secure the Reflash Watch. 

has been reported completed. 


FIRE TEAM LEADER. vou THEN receive the following report: 
The Engineer has given his permission 
to secure the reflash watch. 


FIRE TEAM LEADER. indicate your most important. 
or next action to be completed. 


1. Have the Reflash Watch put his equipment 
away in the Repair Locker. 
2. Dismiss the Reflash Watch watchstander. 
3. Get the Enginneer’s or his designated representative's 
permission to secure the Reflash Watch. 
ire LP 
3 QUIT 
ma. 


Wa 


¡next screen display. 
Steve. the LAST REPORT: 
The Engineer has given his permission 
to secure the reflash watch. 


SHOULD HAVE indicated to you that the action: 
Get the Enginneer's or his designated representative's 
permission to secure the Reflash Watch. 


has JUST BEEN COMPLETED. 

The following action: 

Get the Enginneer's or his designated representative's 
permission to secure the Reflash Watch. 


is a basic level action which doesn’t simplify 
into subactions for further LEARNING. 


removed user session lines 


¡next screen display 
Steve 's Score Level 
5 of 6 83% 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER. you receive the following report: 
The action: Dismiss the Reflash Watch watchstander. 
has been reported completed. 


FIRE TEAM LEADER. you THEN receive the following report: 
The Reflash Watch has been secured. 


THIS COMPLETES YOUR TEST OF THE DAMAGE CONTROL ACTION: 
Secure the Reflash Watch. 
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next screen display 


> ** DAMAGE CONTROPACUOS MA 


Steve. you may now direct the actions to 
properly execute the action: 


Get to the scene equipped and ready to go. 


Your score for this task will be displayed as you carry 


out the actions. -- GOOD LUCK! 


FIRE TEAM LEADER. indicate your most important, 
or next action to be completed. 


1. Take charge of the scene. 
. Get the fire team to the scene. 
3. Get the fire team dressed. 


ho 


. HELP 
. QUIT 
ioe 


Ot wa 


¡next screen display. 
Steve ’s Score Level 
1 of 1 100% 
Steve , you are the " FIRE TEAM LEADER ." 


¡removed user session lines! 


FIRE TEAM LEADER, you receive the following report: 
The action: Get the fire team to the scene. 
has been reported completed. 


FIRE TEAM LEADER. you THEN receive the following report: 


The fire team is at the scene. 


FIRE TEAM LEADER. indicate your most important, 


or next action to be completed. 


1. Get the fire team to the scene. 
. Take charge of the scene. 


wo N 


. Establish phone communications with 
the Repair Locker. 


. HELP 
FOUIT 


ls do 


Ot wa 
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next screen display 
Steve. BEFORE vou can perform the action: 
Establish pnone communications with 
the Repair Locker. 


YOU MUST FIRST perform the action: 


Take charge of the scene. 


OTHERWISE 

vou will only cause chaos and confusion at the scene for the personnel 
who are presently attempting to keep the fire under control. You 
MUST relieve the on scene leader, prior to having your fire team start 
any actions at the scene. 


(Enter a "c." to continue. )c. 


¡next screen display: 
STUDY AND LEARN the following information to help you next time 
vou have a similar situation. 
Below is a breakdown of the specific sub-actions. which make up the action: 
Take charge of the scene. 


1. Visually assess the status of the casualty 
control procedures in progress. 
2. Identify the senior person in charge at the scene. 
3. Relieve the senior person in charge at the scene. 
‘removed user session lines 


next screen display. 
A 
Steve , you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER. you receive the following report: 
The action: Charge the fire hoses. 
has been reported completed. 


THIS COMPLETES YOUR TEST OF THE DAMAGE CONTROL ACTION: 


Get to the scene equipped and ready to go. 
Enter a "c." to continue. 


‘next screen display, 
~~ DAMAGE CONTROL ACTION TEST * * * 
Steve. you may now direct the actions to 
properly execute the action: 
Take charge of the scene. 
¡removed user session lines! 
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next screen display 
Steve s Score Level 
> of 6 Sang 


Steve . vou are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER. you receive the following report: 
The action: Relieve the senior person in charge at the scene. 
has been reported completed. 


FIRE TEAM LEADER. you THEN receive the following report: 


You are now the man in charge at the scene. 
THIS COMPLETES YOUR TEST OF THE DAMAGE CONTROL ACTION: 
Take charge of the scene. 
Enter a "c." to continue. 


[next screen display 


*** DAMAGE CONTROFACTION TESIS 


Steve. you may now direct the actions to 
properly execute the action: 


Perform explosive gas tests. 


Your score for this task will be displayed as you carry 
out the actions. -- GOOD LUCK! 


removed user session lines 


Steve 's Score Level 
5 of 5 100% 


Steve . you are the " FIRE TEAM LEADER ." 


FIRE TEAM LEADER. you receive the following report: 
The action: Sample the space, which had the fire. 

for explosive gases. 

has been reported completed. 


FIRE TEAM LEADER, you THEN receive the following report: 


The explosive gas tests indicate negative explosive gases. 
THIS COMPLETES YOUR TEST OF THE DAMAGE CONTROL ACTION: 
Perform explosive gas tests. 


Enter a "c." to continue. 
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APPENDIX D 


FIRE'S MAJOR SUPPORTING PROGRAM FILES 


File Name: fire 
FIRE: A FIRE TEAM LEADER LEARNING CENTER SYSTEM 
MODE OF OPERATION: COMPLEX FIRE CASUALTY 


AUTHOR: LT. Steve Weingart, USN 


PROGRAM INITIATOR 


fire:- consult(introduction),intro(Cat),abolish(intro,1), 
standby.consult(node actions),standby, 
consult(action results),standby,consult(execute tp order),standby, 
consult(execute tp info).standby, IM 
consult(badconsequences).standby, initiate(Cat). 


initiate(4):- sourcefile( ,4,Filename,Type), 
consult (Filename).clear, execute(Filename,Type).interface(grade). 
initiate(Category):- sourcefile(_,Category.Filename,Type). 
consúlt(Filename),clear. execute(Filename, Type). 


standbv:- clear.blank lines(4). 
writelist(29, "DAMAGE CONTROL'''),blank lines(3), 
writelist(29, ''FIRETEAM LEADER''').blank lines(3), 
writelist(29,' P LEARNING CENTER'). blank lines(4), 
writelist(21.'PLEASE STANDBV WHILE LOADING FILES')), blank lines(2), 
writelist(9, REMEMBER to "PAUSE THE SCREEN MOVEMENT" ’, 
’ with the "NO SCROLL" key,’)), 
writelist(9, AND PROLOG requires all input to be followed’, 
’ by a period("."). >). 


welcome:- clear, blank lines(4), 
writelist(30,'WELCOME TO THE')). blank lines(3), 
writelist(29,”"DAMAGE CONTROL"”'),blank_lines(3), 
writelist(29.| °'F IRETEAM LEADER"! |).blank lines(3), 
writelist(29, | P LEARNING CENTER')), blank lines(4). 
writelist(9 REMEMBER to "PAUSE THE SCREEN MOVEMENT" ’, 
"with ba UNO SCROLL" key,’|), 
writelist(9,/’AND PROLOG requires all input to be followed ’, 
"by a period("."). ’!), standby7. clear. 
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goodby:- clear. blank lines(5). 
writelist(27, "THANK YOU FOR USING THE”). blank _lines(3). 
writelist(29, "DAMAGE CONTROL'' ).blank lines(3). 
writelist(29, ''FIRETEAM LEADER'' ).blank lines(3), 
writelist(29,7 LEARNING CENTER')), blank lines(2), 
writelist(17,|’ For more training START THE PROGRAM OVER.')), 
standby, clear, halt. 


standby7:- system("sleep 7"). 
standby ?7. 


PRIMARY SOURCE FILES 


sourcefile(mainfire,l,help,tp). 
sourcefile(mainfire,2,equipmentops,tp). 
sourcefile(mainfire,3,dcactions,tp). 
sourcefile(mainfire,4,mainfire,ex). 
sourcefile(mainfire,5,prevtraining,tp). 


sourcefile(mainfire,|1],reflash,ex). 
sourcefile( mainfire,|2],injuredperson,ex). 
sourcefile(mainfire,/3),brokenequip.ex). 


PRIMARV AUXILARV PREDICATES 


append(X,[).[X)):- 1. 
append(X,|Y/| List], [Y] New List]):- append(X,List, NewList). 


blank lines(0):- !. 
blank lines(N):- nl, N1 is N - 1, blank lines(N1). 


blank spaces(0):- !. 
blank spaces(N):- write(' '), NI is N-1, blank spaces(N1),!. 


clear:- system("clear"). 
clear. 


nan 
C. 


continue:- nl, nl, write( Enter a to continue.”), read(C), clear, !. 


deleteone(X,]||,/]). 


deleteone(X,|X] List], List):- !. 
deleteone(X,|Y| List], [Y] NewList]):- deleteone(X,List,New List). 
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delete same(... : 
eae ES je E 
delete same(,.X. .X):- !. 
delete _same(X. E — X1.NewY1):- member(Z.Y), member(Z.X). deleteone(Z.Y.NewY), 

deleteone(Z.X.NewX). delete same(NewX,NewY.NewX1,NewY1). !. 
delete same(W.X.W,X):- !. 


describe task('T;, T]):- !. 

describe task( Task, Task Desc):- sourcefile( ,NodeNo,Task, ), 
node action(NodeNo,TaskDesc, ), l. 

describe task(Task,TaskDesc):- assign(|Task|,Task Desc)... 


first([XI List;,X):- !. 


mapfirst([{{L1.L2]],{L1]). 
mapfirst(|{L1,L2]! RestL}, L1) List]):- mapfirst(RestL.List). 


mapsecond({|L1,L2)],/L2]):- !. 
mapsecond({{L1.L2]| Rest L],/L2| List]):- mapsecond(RestL,List), !. 


max task([X],X). 
max task([[Task.Pts,Total,Percent|| List], 'Task.Pts, Total, Percent)):- 
max task(List,| , . ,Max)). Percent >= Max. 


max _task(([Task,Pts,Total,Percent|| List],/Task1.Pts1,Totall1,Max|):- 
max task(List,[Task1,Pts1,Totall.Max ). 


member(X,():- !,fail. 
mem ber(X,| XI _) 
member(X,| | Y'):- member(X, Y). 


min task([X].X). 

min _vask([ Task.Pts.Total.Percent|| List |,[(Task,Pts,Total,Percent]|):- 
min task(List,[ . , .Minj). Percent =< Min. 

min ask([ Task.Pts.Total. Percent| List),Task1,Pts1,Total1,Min]):- 
min task(List,/Task1.Pts1.Totall,Min)). 


percent(Pts,Total.Percent):- Percent is (Pts/Total)*100. 


pr list lines(_,[)):- £. 


pr list lines(Index,[HI T]):- blank_spaces(Index),write(H), nl . 
pr list lines(Index,T). 
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pr list on linef ):- nl... 


;)s- 
pr list on li ne( H. T;):- write( H). tab(l). pr list on line(T)... 


score updatel Task.Score):- describe task(Task,Task Desc). 
retract(overall score(Ptsi.Totall, )). 
Pts is Ptsl 4 Score, Total is Totall — 1, percent(Pts,Total.Per), 
asserta(overall score(Pts.Total.Per)). interface(score,Pts.Total.Per), 
task score update(TaskDesc,Score). 

score update(Task.1):- describe task(Task,TaskDesc), 
asserta(overall score(1.1.100)), 
interface(score,1,1.100), task score update(TaskDesc,1). 

score update(Task.0):- describe _task(Task, Task Desc), 
asserta(overall score(0,1.0)), 
interface(score,0,1,0), task score update(TaskDesc,0). 


select({X! | ,1.X). 
select([X! Y|,N,Member):- Nl is N - 1, select(Y.N1,Member). 


task score update(Task,Score):- retract(task score(Task,Pts1,Totall, )). 
Pts is Pts] + Score, Total is Totall + 1, percent(Pts,Total,Percent), 
assertz(task score(Task.Pts,Total,Percent)). 

task score update(Task,l):- assertz(task score(Task,1,1,100)). 

task score update(Task,0):- assertz(task score(Task,0,1,0)). 


write no list(List,Index,Len):- member(Item,List), 
write(Index), write('. '). writelist(0.ltem), 
deleteone(ltem,List,NewList). Index1 is Index — 1. 
not(Index1>Len), write no _listl(NewList,Index1,Len), !. 


write no listl(List,Index,Len):- write no list2(List,Index,Len). 
write no listl(List,Index,Len). 


write no list2(List,Index,Len):- member(ltem,List), 
write(Index). write(?. >). writelist(0,Item), 
deleteone({Item,List,NewList), Indexi is Index — 1, l. 
not(Index1>Len), write no list2(NewList Index 1,Len). 


writelist(Index.List):- pr list lines(Index,List).!. 
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GAME ENVIRONMENT 


RANDOM TASK GENERATOR 


random(2,N):- retract(seed(S)). N1 is (S mod 3) — 1. N is (N1 mod 2) + 1 
Newseed is (125 * S — 1) mod 4096, asserta(seed(Newseed)).!. 


random(R,N):- retract(seed(S)), N is (S mod R) + 1 
Newseed is (125 * S — 1) mod 4096, asserta(seed(Newseed)).!. 


random yes _no(CasFac,YesNo):- random(100.N). experience level(ExpLev, ), 
Level is ExpLev - CasFac ((N < Level,performtask(no, YesNo)); 
performtask (yes, YesNo)).!. 


performtask(X,X). 


TASK EXECUTOR 


execute(Task,ex):- start(Task.Start).check casualty code, 

correct action order(Start,Task). role(Task,Role), 

check last report( Task), 

abolish(active roie.l), asserta(active role(Role)). 

successor( Task Start, Newstate),. 

asserta(previous node(Task,Start)).action seq(Task, a 
execute(Task,tp):- tp file type(_,Task.Type), execute tp(Task,Type), ! 
execute(Task.nex). 


check casualty code:- handlecasualty code(HC). 
check casualty _code:- asserta(handlecasualty code(0)). 


check last report(Task):- last report(Task,Report). 
check last report(Task):- retract(last report( .Report)), 

asserta(last report(Task.Report)). 
check last report( ). 


action seq( Task.complete.Statelist). 

action seq(Task.State.Statelist):- not(member(State.Statelist)). 
test _user(Task.State.Statelist). action(Task.State.Statelist). 

action seq(Task.State,Statelist):- test user( Task,State.Statelist). 
update results(Task.State,Statelist.Nstatelist),remove reflash. 
action(Task,State.Nstatelist). 
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action( Task.State.Statelist):- node action(State. .Type). 
complete action(Task.State.Type). 
action results(Task.State,¡ HC .Cas). 
(var(Cas): complete casualty(Task.State.Nstate.HC.Cas)). 
((var(Nstate).successor(Task.State,Nstate));true), 
action seq(Task.Nstate, ¡State Statelist)). 


complete action( Task.State.nex):- interface(comp action, Task,State). 
complete action(Task,State. ):- casfac(Task,State , Casfac), 
random ves no(Casfac. VesNo), VesNo — no, 
interface(comp action, Task,State). 
complete _action(Task. State.Tvpe):- interface(ncomp action, Task,State), 
sourcefile(Task.State.File, Type), consult(File), 
((Type = tp.continue);true), 
nl. execute(File, Type), 
interface(comp_action,Task.State). 


complete casualty(Task. , .HC,Cas):- casfac(_,HC,Casfac), 
random yes no esNo), YesNo = no. 

complete casualty(Task.State,Nstate,HC,Cas):- random(2,N), 
select(Cas.N.Casualty), 
asserta(result(Task.State,HC,Casualty)), 
interface(announce cas.HC,Casualty). 
check casualty code, 
retract(handlecasualty code(OldHC)), asserta(handlecasualtv code(HC)), 
sourcefile( , HC],File.Type), 
((reflash(HC), assign(|1,1,2,2/.Nstate)); 
( consult (File), nl. 
execute(File, Type). cleandatabase(_,/HC|,Type), 
retract(handlecasualty code(OoldHC)),retract(last report(File,Rep)), 
asserta(handlecasualty code(0)))). 


reflash(1). 
assign(X.X). 


casfac( Task.CasNo.Casfac ):- 
task score(CasNo.Pts,Total. Percent), 
((Percent < 90. Casfac is Total - Pts, (Casfac =< 25; Casfac is 25)); 
(Casfac is -15)),!. 

€asiac( mee: 


update results(Task,X,|X) List),List). 


update results(Task,X, Vi List/,Statelist):- retract(result(Task,V, , )). 
update results(Task.X,List,Statelist). 
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remove reflash:- handlecasualty code(1).retract(handlecasualty code({1)). 
retract(last report(HC.Rep)).asserta(handlecasualty code(0 i 
remove reflash. 


correct action order(Start,Task):- bagof(¡X,Y].successor(Task.X.Y),BagList). 
mapfirst( BagList,List), assertz(successor(Task,State.State)), 
makeunique(List,Ulist), deleteone(Start,Ulist,UniqueList), 
asserta(action order(Task.UniqueList)). 


test user(Task.State.Statelist):- action order(Task,ActionList), 
exp action list(State,ActionList.ExpList), 
test( Task.State,ExpList), check _save dummy items. 


exp action list(State.List E: - experience level(Exp, ), 
difficulty(Exp.Dif), split _list(Dif,State, List, ActionList), 
length(ActionList, Len), 
((Len < Dif, extend(Len.Dif,State,ActionList,ExpList)); 
(true,assign(ActionList,ExpList))). 


difficulty (90,3). 
difficulty (75,6). 
difficulty(60,12). 


3,.X;,X.A],,X,A}). 

3-A, |A.X] ’ ¡AX ) p 

3.X,X.A. BIL, X,A,BI). 

3,X,1A.X.BILi,;A,X,B)). 

3,X,,A,B.X),!A,B,X]). 

3.X,, Y! List..ActionList):- split list(3,X,List,ActionList). 


split list 
split list 
split list 
split list 
split list 
split list 


OO AS AS A 


split_list(6.X,/X,A.B,C.D,E| L],[X,A.B,C,D,E]). 

split list(6.X,¡A,X.B.C.D,ElL],¡A.X.B,C,D.E]). 

split list(6.X,,A.B.X.C,D,E| L],/A.B.X,C,D,E]). 

split _list(6,X,¡A,B,C.X.D,E:,¡A.B,C.X,D.E]). 

split list(6,X,/A,B.C.D,X,E;,(A.B.C.D.X.EJ). 

split list(6.X,(A,B,C,D,E.X;,JA.B,C.D,E,X)). 

split_list(6,X, Y] List].ActionList):- length(List.Len), Len > 6, 

split list(6.X.List,ActionList). 
split list(6.X,List,ActionList):- split list(3,X.List.ActionList). 
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split_list(12.4. X.A.B.C.D EPG she Inwibis the NE C DE 
split list(12 x3 AX.B.CDEF GHI J Riist. A- NBC.D.EF.G.H.1.J-Ki). 
split list(12.X..A.B.X.C.D.E.F.G.H.LJ.K: List), A.B.X.C.D.E.F.G-H.1.J.k'). 
split list(12.X. A-B.C.X.D,.E.FG HLIK List iB CS DEC 
split_list(12,X,|A.B.C.D,X,E,F,G.H1,J,K] List|,|AgB.C_D XE BWG HI ILKI) 
split_list(12.X,[A.B.C.D.E.X.F,G,H,1,J,K], [A,B,C,D,E,X,F,G,H,1.J,K]). 
split_list(12,X,[A,B,C.D, E, FXG HTI KAB. C DET TA 
split_list(12,X,[A,B,C.D,E.E,G,X,H.1.J,K|,/A.B,©,D Eh (Grex ipl Je re): 
split_list(12,X,[A,B,C.D,E,F ,G,H,X.,1,J,K],[A,B,C,D,E,F,G,H,X,I,J,K]). 
split _list(12,X,[A,B,C.D.E: PG HITAJIKA B,C DIE P GHEE 
split “intl? XA BCD Eee A,B,C, DIE, GH. L, IAS K |i 
split_list(12,X,[A,B.C.D,E.F,G,H,1,J,K,X],[A,B,C,D,E.F,G,H,1,J,K,X]). 
split list(12,X,/Y| List;,ActionList):- length(/Y|List|,Len), Len >12, 

split list(12.X.List.Action List). 
split list(12,X.List,ActionList):- split list(6.X.List,ActionList). 


extend( X.X,State.List.List). 
extend(Len. Dif.State,List. NewList):- action order(mainfire.Actions), 
random(20,N). 
select( Actions,N,Dummv),not(compare (Dummv.State,above)), 
savedummymenuitems(Dummy), 
append(Dummy,List,Nlist), Len] is Len + 1, 
extend(Len1,Dif,State,Nlist.New List). 
savedummymenuitems(Dummy):- not(saveextendeditems(ExtItems)), 
asserta(saveextendeditems({Dummy))). 
savedummymenuitems(Dummy):- retract(saveextendeditems(ExtItems)), 
append(Dummy,Extltems,NExtltems).asserta(saveextendeditems(NExtltems)). 


check save dummy items:- retract(saveextendeditems(Dummyltems)). 
check save dummy items. 


1,1). 
| 


makeunique( XI Listi. UniqueList):- var(X). makeunique( List.UniqueList). 
makeunique( |X! List! ,UniqueList):- member(X,List), makeuniquefList,UniqueList). 
makeunique( XI List] ,[X. UniqueList|):- makeunique( List, UniqueList). 


makeunique 
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S ODEA ITEC FERT CHOICE COMPARER 


test(Task.State.ExpList):- 

interface(menu.ExpList.UserAction). 

((UserAction = State. score update(Task,1).retract(previous node(Task.Prev)), 
asserta(previous node(Task.State))): 

(previous node(Task.PrevNode).last report(Task,Report), 

handlecasualty _code(HC). 

retract(seed(S)), S1 is S +1, asserta(seed(S1)), 

determine SM(PrevNode,UserAction.HC,ForgotAction,Case), 

teaching module(UserAction.ForgotAction,Report,Case), score update(Task.0)), 

nl.write("YOUR LAST REPORT WAS: >), nl, writelist(0.Report).nl,nl, 

test(Task.State.ExpList)). : 


STUDENT MODEL 


determine SM( .User.HC. .0):- saveextendeditems(Dummyltems), 
member( User. Dummvltems), not( HC — 0). 

determine SM(_, .HC. .1):- not(HC= 0). 

determine SM(Prev.User, , ,2):- compare (User.Prev,less). 

determine SM(Prev.User, . ,3):-compare (Prev.User,equal). 

determine SM(PrevAction,UserAction,.HC.MostGeneralAction,4):- 
wanted (Prev Action. UserAction.ForgotNodes), 
maplength(Forgot Nodes, NewF orgot Nodes). 
minlength(NewForgotNodes,Len). not(Len = 0). 
collect shortest(Len.NewForgotNodes.Most General), 
greatestmostgeneralnode( Most General. Most General Action). 

determine SM(_, , , ,5). 


[|,/, equal):- 
.L. a 
compare a E 


A 
(i 
(A 
compare | Belew): L 
a 
A 
A 


compare 
compare 


compare 
compare 


X'LI), ¡Yi L2],greater):- X>Y.!. 
X. L1|,: Yi L2].1ess):- X<Y. !. 

compare ([X:¡L1|,X' L2].A):- compare (L1.L2.A). ! 
wanted(P.U.N):- bagof(X.wanteditem(P,U,X).N), !. 
wanteditem(P.U.M):- node action(M, , ).compare (M.P,greater), compare (M,U,less). 


maplength(|},_):- !. fail. 


maplength([X!,[¡X,Y]]):- length(X, Y).!. 
maplength([XI L1],[(X, Y] L2)):- length(X, Y), maplength(L1,L2), !. 
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minlength(.'X.Y:,.Y):- 1. 
minlength(:. X.V LI .Z):- minlength(L1.Z). Z=<Y.!. 
minlength(':X. Y] L1 .Y):- minlength(L1.Z). Y<Z.!. 


collect shortest(Len.List. ):- asserta(shortitems(| )).member( X.Len;.List), 
retract(shortitems(Sl)), append( X.Len .SI, Shortltems), 
asserta(shortitems(Shortltems)).fail. 

collect _shortest(Len.List.Shortltems):- retract(shortitems(Shortltems)). 


greatestmostgeneralnode(|[X, ||,X). 

greatestmostgeneralnode(ListGenNodes, ):- asserta(greatest([0])), 
member((X, |.ListGenNodes).member([Y, |,ListGenNodes), compare (X,Y greater), 
retract(greatest(G)). ((compare (X.G,greater), asserta(greatest(X))); 
asserta(greatest(G))), fail. 

greatestmostgeneralnode(_,MostGeneralNode):- retract(greatest (MostGeneralNode)). 


TUTORING MODULE 


teaching module(State, .Report,0):- user(Name),clear, 
write( Name), write(”, your choice of: ').nl, 
node action(State,StateDesc, ),writelist(0,StateDesc),nl,nl, 
write('has nothing to do with the current most important'),nl. 
write('action to be performed. ` The LAST REPORT: >.nl, 
writelist(0,Report),nl,nl, 
write(’should help you decide what to do next.”), blank lines(4), 
write( (Enter a "c." to continue.)’), read(C),clear, try again message. 


teaching module( , , ,1):- user(Name), clear. 
write(Name), write(’, you have FAILED TO REALIZE that a REFLASH, ’), nl, 
write PERSONNEL INJURY or EQUIPMENT FAILURE CASUALTY 
has just occurred’), 
nl,write(’or you’’ve taken the WRONG IMMEDIATE ACTION!’),nl,nl, 
write(’You MUST take the CORRECT IMMEDIATE ACTIONS in the 
CORRECT ORDER’), 
nl, write(’to CONTROL and RECOVER from this CASUALTY.’), nl, 
blank lines(2). display node breakdown(State,0), try again message. 


teaching module(State, . ,2):- user(Name). clear, 
write( Name), write(". you YOU HAVE ALREADY COMPLETED the action: ”). 
nl. node action(State.StateDesc, ). writelist(0,StateDesc), 
blank lines(4). 
write('(Enter a ''c.'' to continue.)'), read(C),clear, trv again message. 
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teaching module(State. .Report.3):- user Name). clear. 
write( Name). write(”. the LAST REPORT: `). nl. 
writelist(0.Report). nl. 7 
write( SHOULD HAVE indicated to vou that the action:’). nl, 
node action(State.StateDesc, ). writelist(0.StateDesc). 
nl. write(*has JUST BEEN COMPLETED..’). blank lines(2). 


display node breakdown(State,0), try again message. 


teaching module( .State.Report,4):- bad consequence(State.Successor,BCD), 
node _action(State. StateDesc, ), node action(Successor,SuccessorDesc, ), 
clear. user(Name).write(Name), 
write(”, BEFORE you can perform the action:’), nl, 
writelist(0.SuccessorDesc). nl, ’ 
write( YOU MUST FIRST perform the action:’), 
nl.writelist(O.StateDesc), nl,write” OTHERWISE >”), nl, 
writelist(0.BCD).blank lines(2). display node breakdown(State,0), 


try again message. 


teaching module(State, ,Report.5):- bad consequence(Prev.State, ). user(Name). 
clear. write(Name). write(*, your PREVIOUS ACTION: >), nl.nl. 
node action(Prev.PrevDesc, ). 
writelist(0,PrevDesc). nl. 
write('hasn”t been completed yet. You SHOULD ’), 
nl. write”? HAVE REALIZED THIS by the LAST REPORT you received: °), 
nl.nl. 
writelist(0.Report). blank lines(2).display node breakdown(Prev,0), 
try -again message. 


display node breakdown(State.No):- node action(State.StateDesc,Type). 
Type=nex. 
write('The following action: '). nl, 
writelist(0,StateDesc).n!, 
write('is a basic level action which doesn 't simplifv ').nl. 
write('into subactions for further LEARNING. '),blank lines(5), 


write(' (Enter a ''c.'' to continue.)'), read(C),clear.!. 


displav node breakdown(State,No):- node action(State.StateDesc.Tvpe). 
Type=tp, tp file type(State,Taskname.info). continue, 
consult(Taskname),clear, 
execute(Taskname,tp), !. 
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distiay node breakdown(State. No): node. _action(State. StateDesc. Type). 
Type=tp. “asserta(order _steps(_)). 
tp file type(State.Taskname. ). continue. consult(Taskname). clear. nl. 
write(? *** NEW SUB ACTION BREAKDOWN *** 7), nl. nl. 
write('Below is a breakdown of the specific sub-actions, '). 
write(” which make up the action: ?). 
nl, writelist(0.StateDesc), nl, 
operation step(Step), save states(Step), fail, !. 


save states(Step):- retract(order steps(Operation Steps)), 
abolish(order steps,l), 
append(Step.Operation Steps.NOp Steps), asserta(order steps(NOp Steps)), 
' ° 


display node breakdown(State,No):- node _action(State.StateDesc,Type), 
Ty pe=tp. retract(order  steps(Op Steps)), 
length(Op Steps.Len). write no list(Op Steps.1.Len), continue, !. 


display node breakdown(State,0):- nl.asserta(xstates(|])), 
write(”(Enter a "c." to continue.)”). read(C).clear, 
write STUDY AND LEARN the following information to help you next time’). 
nl. write('vou have a similar situation. '). nl. 
write(’ Below is a breakdown of the specific sub-actions,’), 
write(' which make up the action: '), 
nl, node_action(State.StateDesc,Type), writelist(0.StateDesc),nl. 
display _node(State,5,1).!. 


display node breakdown(State,1):- asserta(xstates(|])), 
write *** NEW SUB ACTION BREAKDOWN *** >”), ni, 
write('Below is a breakdown of the specific sub-actions, '), 
write(' which make up the action: °), 
nl, node action(State,StateDesc, Tvpe), writelist(0,StateDesc),nl, 
display node(State,5,1),!. 


display node breakdown(State.2):- asserta(xstates((!)), 
write(” *** REMINDER OF PREVIOUS ACTION BREAKDOWN *** >), nl, 
write(’Below is a breakdown of the specific sub-actions, °), 
write(’which make up the action: ?), 
nl. node action(State,StateDesc. Type), writelist(0.StateDesc),nl, 
display node(State,5.2).!. 
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display node(State.Index. }:- node action(Xstate.\statedesc. }. 
compare (Xstate.State.directlybelow). B 
save xstates( Xstate.\statedesc ).fail.!. 

display node(State.lndex. ):- get xstates(Subactions). 
mapsecond (Subactions.List Task Desc). 
length( List Task Desc.Len). 
write no list(List TaskDesc,1,Len), fail, !. 

display node(State. .1):- furtherbreakdownmess(State). 

display node(State, . ):- retract(xstates(X)).!. 


get xstates(Subactions):- xstates(Subactions), l. 


save xstates(XstatePair):- retract(xstates(X)), 
append(XstatePair.X.NXstates), 
asserta(xstates(N Xstates)).l. 


choose xstate(N.XstatePair):- xstates(XS), select(XS.N,XstatePair),clear,l. 


furtherbreakdownmess(State):- blank lines(1), 
writelist(0,/'Do you want more breakdowns of these sub-actions?”, 
‘INDICATE WHICH SUB-ACTIONS USING FORMAT "[#,21.", 
" otherwise ENTER "c." to continue.” ), 
read(Choice),((Choice = c,!,fail); 
(!.member(Z.Choice),choose_xstate(Z.AstatePair). 
first( XstatePair.XstáteNo). 
display node breakdown(State,2).nl. 
display node breakdown(AstateNo.1), 
nl,write( Enter "c." to continue: ”).read(C).fail)). 


try again message:- clear. blank lines(5). user ame). write(Name). 
write(’, now that you understand why your st choice of actions’).nl. 
write('wasn”t the best choice. 1”Il repeat th: last °), 
write(’report you received’), 
nl. write(’and the same choices. CHOOSE THE BEST ACTION. GOOD LUCK"). 


nl, write(’(Enter a "c." to continue.)”).read(C). clear. 
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VALIDA TESEI 


validate inp(Inp.Max.Inp):- integer(Inp). Inp >= 1. Inp =< Max. !. 

validate inp(Inp.Max,NewChoice):- blank lines(2). user(Name). write( Name). 
write(’, your input was incorrect, please reenter your choice:’). 
read(Choice), validate inp(Choice,Max.NewChoice), !. 


validate(Choice,Choice):- choice(Choice). 

validate(Choice,Inp):- nl, write(7 PLEASE enter a "yes." or "no.": ’), 
read(Choicel), validate(Choicel.Inp).!. 

choice(yes). 

choice(no). 


USER INTERFACE ROUTINES 


DISPLAY USER RUNNING SCORE 


interface(score,Pts, Total,Per):- clear, user( Name), 


pr list on linef 'Name,'s Score Level')), 
write(’ 9): 
pr list on line(( Pts of Total A 


active role(Role), pr list on line([Name,”, you are the "”,Role.,”.""”]). 
interface(score,Pts,Total,Per). 


132 


USER ACTION MBE GENERA TOR 


interface(menu.ActionList.UserAction):- 
length(ActionList.Len). mixup(ActionList.' .MxList.Len). 
menu(MxList.1,Len). 
N is Len ~ 3. read(Choice), validate inp(Choice.N,Inp), 
((req aid(Inp.Len). last report( ,Report), 
nl,write( YOUR LAST REPORT WAASS: '), nl. writelist(0,Report),nl,nl. 
interface(menu,ActionList.UserAction)); 
(select(MxList.Inp.UserAction))), !. 


mixup(!|.X.X.0). 
mixupi List.Oldlist.NList.Len):-- random(Len.N), select (List.N,Item), 
append(ltem.Oldlist,NewList). deleteone(Item,List,List1), 
Len1 is Len - 1. | 


mixup(List1.NewList.NList.Len1). 


list  menu(MxList.Index.Len):- select(MxList.Index.ltem), 
node action(Item.Action, ). 
write(Index), write('. '). writelist(0.Action). l. Index < Len. 
Indexl is Index — 1. 
list_ menu(MxList.Index1.Len). 


menu(M«xList.Index.Len):- active role(Role), 
write(Role), write('. indicate your most important,”), nl, 
write(' or next action to be completed.’),nl, nl, 
list menu(MxList.Index,Len). 
menu(MxList.Index.Len):- nl.user_aid(Len,1). 


menu(_, , ). 


user aid(Indx,1):- Indx1 is Indx + 1, !, aid(I,Aid, ), 
write(Indx1), write(*. ’), write(Aid), nl, I1 is I + 1, 
user aid(Indx1.Í1). 


aid(1. HELP '.help). 
aid(2, QUIT' .quit). 


req aid(UserChoice,Len):- UserChoice > Len. N is UserChoice - Len, 
aid(N. .Aidname). 
((N=1, consult(Aidname). executeaid(Aidname).score update Aidname.0)): 
(interface(grade), goodby)). 


133 


DIRECT USER TO COMPLETE TASK 


interface(ncomp action.Task.State):- nl. active role(Role). 
write(Role). write(", you MUST now DIRECT THE ACTIONS to complete the `). 
nl, write(*following TASK: ”), node action(State.StateDesc, ). 
writelist(0.StateDesc). nl. 


ANNOUNCE CASUALTY 


interface{announce cas,HC,Casualty):- active role(Role), 
write(Role). write(?, you THEN receive the following report: >), nl, 
writelist(0.Casualty), nl, nl,-sourcefile(_,¡HC|,CasName, ), 
asserta(last report(CasName,Casualtv)). 


TASK COMPLETION REPORT 


interface(comp action, Task,State):- nl, 
active role(Role), write(Role), 
write(', vou receive the following report: '), nl. 
write('The action: '), node action(State.Action,NodeTv pe), 
writelist(0, Action), write('has been reported completed.'). ni,nl. 
assign(|’The action: ’,Action,’ has been reported complepes: "|, Report). 
check last _report(Task), 
retract(last report(Task, Rep)). asserta(last report(Task,Report)), 
results of action(Task,State,NodeType). nl. 
interface(comp action, Task,State). 


results of action(Task.State,NodeType):- random(2,N), ok nok(N,Type), 
action results(Task.State,Type.Results), 
length(Results.Len). random(Len,N1), select(Results,N1,Nresult), 
analyze result(Task.State,Type,Nresult,NodeType). 


ok nok(2.ok). 
ok nok(1.nok). 
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analyze result{Task.State. New Type. New Result. NodeType):- 
retract(result(Task.State.OldType. )). 
OldType = NewType. o 
cleandatabase( Task.State,NodeTv pe). 

analyze result(Task.State. New Type.NewResult.NodeType):- 
asserta(result(Task.State.NewType,NewResult)), 
active role(Role). write(Role), 
write(’, you THEN receive the following report: '), nl, 
writelist(0.NewResult), check last report(Task). 
retract (last report(Task.Rep)).asserta(last report(Task,New Result)), 
cleandatabase( Task.State, NodeTv pe). 


cleandatabase( Task.State,tp). 

cleandatabase(Task.State, ):- sourcefile( Task.State.File, ). 
retract(action order(File.List)), retract(role(File.Role)). 
retract(start(File, )). retract(previous node(File. )), 
cleansuccessor(File).cleansuccessorinfo(File). 
cleanresults(File). cleansource(File). 

cleandatabase( Task,State, ). 


cleansuccessor(File):- retract(successor(File, , )). fail. 
cleansuccessor(File). 


cleansuccessorinfo(File):- retract(successor rule info(File, , )),fail. 
cleansuccessorinfo(File). 


cleanresults(File):- retract(results(File, , , )), fail. 
cleanresults(File). 


cleansource(File':- retract(sourcefile(File, , , )), fail. 
cleansource( Fil: 
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LSER PERFORMANCE ME EKORT 


interface(grade):- user(Name). 
write('Enter a “c.” to continue. ). read(C). clear. 
writelist(24,'FINAL GRADE OF PERFORMANCE').nl. 
pr list on line([ Congratulations '.Name.' you”ve survived!”). nl. 
write('Remember there”s always room for improvement in Damage Control’), 
nl, write(’Casualty Training. Your life, your shipmate’’s. and your ?), 
nl, write(’ship’’s survival may someday depend on your KNOWLEDGE as a’), 
nl, write MAN IN CHARGE of a casualty. The following is a report of ?), 


nl, write('vour performance: '). nl, nl. 


write(’Casualty Task Points Total Percent Grade’), 
nl. overall score(Pts,Total,Percent), 

write(’Overall Score D 

pr list on line(/ Pts,’ ’, Total,’ ' Percent)), 


writelist(0, "Enter a "c." to continue.”]), read(C), 

task score(Task1.Pts1,Totall,Percent1). nl, describe_task(Task1,TaskDesc), 
writelist(0,Task Desc), 

pr list on line(f'Pts =”.Pts1.' Total = ’,Totall.’ Percent Grade =), 
write(Percent1), fail. 


FOLLOW ON TRAINING OPPORTUNITIES 


interface(grade):- nl, write(’Enter a ’’c.” to continue.”), read(C), clear, 
writelist(0, "FOLLOW ON TRAINING OPPORTUNITIES” ), 
write(’For further training on the types of damage control actions or >), nl, 
write(’equipment operations you just directed : °), nl, 
write(’Enter a 1. To Quit’), nl, 
write(' 2. Previous Fire Casualty Operations Training’), nl, 
read(Choice), validate inp(Choice,2,Inp), ((Inp=1, goodbv): 
(sort task list(TrainTasks), 
cleanentiredatabase, asserta(old performance(TrainTasks)), 
initiate(5))), goodby. 


cleanentiredatabase:- abolish(location,6), abolish(overall score,3). 
abolish(task score,4). abolish(result,4). abolish(action order,2). 
abolish(successor.3). 


sort task list(TrainTasks):- task list(TaskScores), 
deleteone(|'mainfire;, . , |,TaskScores,NewTaskScores). 


L 


training order(New TaskScores, TrainTasks). 
task list(TaskScores):- 


bagof(|Task,Pts,Total,Percent!, 
task score(Task,Pts,Total, Percent),TaskScores). 
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training order( . ). 

training order X.X ). 

training _order(List. L1.L2 N3List ):- max task(List.L1). 
deleteone(LI.List.NIList). min task(NIList.L2). 
deleteone(L2.NIList.N2List). 


training order(N2List,N3List). 
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File Name: execute tp info 
INFORMATIONAL TEST PROCEDURE TASK EXECUTOR 


Author: LT Steve Weingart. USN 


execute tp(Task,info):- asserta dummy location, 
tp file tvpe(TPNo,Task. ). node action(TPNo,Task Desc, ), 
user directions info(TaskDesc), 
operation step(Review), writelist(0,Review), continue, display score, 
continue, remove tp info, retract(seed(Seed)), Seed] is Seed + 57. 
asserta(seed(Seedl)). 


user directions info(TaskDesc):- user(Name), clear, reference(Ref), 


write(” XX KNOWLEDGE REVIEW *** >.hnlni, 

nl, write(Name), writelist(0,/, you will be shown a review of ’, 

‘important knowledge required in the performance of Task: ')), nl. 
writelist(0,Task Desc), nl. nl, writelist(0,/ 

“STUDY AND LEARN THIS INFORMATION and for further guidance refer ', 
"to reference: ',Ref. 

‘you will not be graded on this review.” ), continue. 


display score:- overall score(Pts,Total,Per),interface(score,Pts,Total,Per). 
displav score. 


remove tp info:- abolish(operation step,l). 
abolish(task name,l), abolish(reference,l). 


asserta dummy location:- 


asserta(location(mainfire, ADMIN OFFICE’,’Q’,’03’,’19’,’02’)). 


tp file type([1,1,1,1,5!,chargefirehoses,info). 
tp file type([1,2,1,2,1;,choosedesmethod,info). 
tp file type([1,2,5,1],debrief.info). 

tp file type([1,1,1,1,2.2|,determineroute.info). 
tp file tvpe((2,2,2.1).firstaid,info). 

tp file type([1,2,2,3),fArstoxygentest,info). 

tp file type([1,1,1,1,2,1,2;,idspace,info). 

tp file type([2,2,1|,removeinjured.info). 

tp file type([1,2,2,4].secondoxygentest,info). 
tp file type([1,1,2,3),setreflashwatch,info). 

tp file type([1,1,2,1,2|,activatehose,info). 
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File Name: execute tp order 
Pest TOC DURE ORDER DEPENDENT TASK EXECUTOR 


Author: LT Steve Weingart. USN 


execute tp(Task.order):- tp file type(TPNo.Task, ). node action(TPNo,TaskDesc, ), 
user directions order(TaskDesc). 
bagof(X.operation step(X).Operation sequence), 
length(Operation sequence.Len). asserta(correct seq(Operation sequence,Len)). 
user tp test(Operation sequence). remove tp order. i 


user tp test(Operation sequence):- 
correct seq(CorrectSeq.Len). asserta(testmenu(1.CorrectSeq)), 
mixup(Operation E uence .MxTpList1.Len), asserta(testmenu(2.MxTpList1)), 
mixup(Operation sequence.||,MxTpList2.Len). asserta(testmenu(3,MxTpList2)), 
menu tp(l.Len). 


menu tp(Index.Len):- user(Name), task name Task). 
tp file tvpe(TPNo.Task, ), node action(TPNo.TaskDesc, ). 
clear. write(Name). write(’. are the following steps the correct sequence to’), 
nl. write('perform the task: °), 
nl. writelist(0.Task Desc). nl, nl, random(3,N), testmenu(N.MxTpList). 
write no Po Index. Len), nl, 
write(’Enter a "yes." or "no.": '), read(Choice), 
validate(Choice.Inp), E nea 
((Inp = no. analyze no(Operation seq.MxTpList.Index,Len)): 
analyze yes(Operation seq.MxTpList)). 


analyze no(Operation seq.MxTpList.Index.Len):- not(equal(Operation_seq,MxTpList)). 
menu tp(Index,Len). 

analyze no(Operation seq,MxTpList, . ):- user missed correct_seq. task_name(Task). 
score update(Task.0). continue. 


analyze yes(Operation seq.MxTpList):- equal(Operation seq.MxTpList), 
user is correct. task name(Task). score update(Task.1). continue. 
analyze _yes(Operation _seq.MxTpList):- user yes is incorrect. 
task name(Task). score update(Task.0). continue. 


equal((XI, XI). 
equal(IX List1j,/XI List2):- equal(Listi.List2). 





user missed correct seq:- nl. nl. user(Name). write(Name), 
writelist(0,/”, you are incorrect. the above sequence is correct!”, 


"STUDY AND LEARN it before you continue.”|). continue. 
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user yes is incorrect:- user( Name). write) Name). 
writelist (0... you are incorrect. the above sequence’. 
‘is not correct! Below is the correct sequence. `. l 
'STUDV AND LEARN it before vou continue. ). nl. nl. 
correct seq(Operation seq.Len). write no list(Operation seq,1,Len). 
continue. 


user is correct:- nl, nl, user(Name), write(Name), 
writelist(0,|’, your answer is correct.”|), continue. 


user directions order(TaskDesc):- user(Name). clear, reference(Ref), 
write(' OS KNOWLEDGE TEST PROGRAM Ean 
nl. write(Name). writelist(05/7, you will be shown various sequences of’, 
‘operational steps to perform the Task: ”|), nl, 
writelist(0.Task Desc). nl, nl, writelist(0,| 
"The reference for this task”s sequence of operational steps is the”), 
write(Ref).nl. nl. writelist(0,| 
"If the sequence is correct, you should enter a "yes." °, 
‘otherwise a "no." if its incorrect. If your answer is incorrect,’, 
'vou 'Il be shown the correct sequence of steps and given O points’, 
"for this test. If your answer is correct you’’!l be given 1 point’, 
for this test.’,’ °]), continue. 


remove tp order:- abolish(task name.1). abolish(operation step,1). 
abolish(reference,1). abolish(testmenu,2), abolish(correct seq,2). 


tp file type(/1.1,1.1,1,2.2}.checkoba,order). 

tp: file tvpelll. Dear a A EG ata order). 

tp file tvpe' 1,2,3,2 .dewater.order). 

tp file type: 1.1,1.1.1.2,5.donfacep.order). 

tp file tvpe( 1. 1,1.1.4,.estphonecoms.order). 

tp file type(|1.1,2.2}.extinguishfire,order). 

tp file tvpe( 1,1,1.1.1.2.4 ;instcan.order). 

tp file type(|1.1,1.3.3:.manadjspaces.order). 

tp file type(/1.1,1.2.1 .locatecirbrkr.order). 

tp file type(|1,1,1, 1,1,2, 3|,placeonbody ,order). 

tp file tvpe( 1.2,1.2.2 .removalpathest.order). 
( 
( 
( 
( 
(2 
( 
(5 


tp file type({1,2,1.1 pu ,testex pequip,order). 

tp file type([1.2,2,2|.testoxygentester,order). 

tp file type(1.help,tp). 

tp file type(2.equipmentops,tp). 

tp file type(3.dcactions,tp). 

tp file type(5,prevtraining,tp). ` 


| 
| 
| 
1. 
| 
tp file tvpe( 1.2,1.1,3).sampleexspace.order). 
| 
| 
la 
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File Name: mainfire 


MIN FIRE CASTALTY SOBNARIO SOURCE FILE 


Author: LT Steve Weingart. USN 


successor(mainfire,|0,0,0,0],/1.1,1,1]):- initiate task(mainfire), 


abolish(initiate task,1). 
successor(mainfire,/0,0,0,0,,1,1,1.1)). 


successor (mainfire.State.Successor ):- 


successor rule info(mainfire.State.Successor), 


not(result(mainfire.State.nok, )). 


successor rule info(mainfire,|1.1,1,1' A 
successor rule info(mainfire. 1. 1.1 Pl 1; lakeġji s- 
successor rule info(mainfire,/1,1,1,3/,11.1.2.1)):- 
successor rule info(mainfire, 112 11], L-1220: 
successor rule info(mainfire, 1,1.2,2, ju. 1,2,3]):- 
successor _rule _info(mainfire,|1.1,2 ali 1,1,2,4]):- 
successor _rule _info(mainfire,|1.1,2,4), a 2,1,1)):- 
successor _rule _info(mainfire,|1,2,1,1],/1, 2,1,2]):- 
successor rule info(mainfire,/1.2,1,2),(1,2,2,1)):- 
successor rule info(mainfire, ee pe? 1) ,|1525252|):- 
successor _rule _info(mainfire,|1.2,2,2],[1,2,2,3)):- 
successor rule  info(mainfire,/1.2.2,3),/1.2.2,4)):- 
successor rule info(mainfire,(1.2.2 Ali (123.1) 
successor _rule 'info(mainfire, 1. 273071: 2.,322)/)s- 
successor rule _info(mainfire.|1.2.3 2). e o 
successor rule _info(mainfire.'1.2.4, 1), 1,2.4,2]):- 
successor rule info(mainfire,|1.2.4. 2/,i1. 25 ,1)):- 
successor _rule _info(mainfire,|1.2,5.1/,[1.2.5,2)):- 
successor rule _info(mainfire, 1.2.5. > M2: 5.3): 
successor rule _info(mainfire. 

( 


successor rule _info(mainfire. ,|1,1,3.2]):- 


role(mainfire. FIRE TEAM LEADER’). 
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1.2,5.3/.complete):- 


handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0). 
handlecasualty code(0) 
handlecasualty code(0) 
handlecasualty code(0) 
handlecasualty code( 
handlecasualty code(0 
handlecasualty code( 
handlecasualty code(0 
handlecasualty code(0 
handlecasualty code(0). 


handlecasualty code(1). 


Initiate task(mainfire):- 

random(5.Level). random(100.Frame). random(6.Ctr). 
random(6.Type). space(T y pe.Desc.Sym). 
asserta(location(mainfire.Desc.Sym.Level.Frame.Ctr)). 

nl. write( DING DING DING DING DING’), 
ni. write FIRE FIRE FIRE FIRE Oni 
pr list on linef 

FIRE IN '.Desc,. COMPARTMENT ’.Level,’-’,Frame,’-’,Ctr,’-’,Sym]), 
nl. write AWAY THE REPAIR PARY FIRE TEAM AWAY"), nl, 
asserta(result(mainfire,|0.0,0.0).ok, 

"The ship has been informed of the location of the fire.'))), 
asserta(last report(mainfire, 

"The sh > has been informed of the location of the fire.” )), 

blank 1  s(3). display role. 


display  -=:- user(Name), role(mainfire.Role), 
pri on line([Name,”, you are now the "’,Role,’."’|), nl, nl. 


(1."A” DIVISION BERMMAINC*-L”). 
(2.”E” DIVISION BERTHING’,’L’). 
space(3. SUPPLY STOREROOM’,’A’). 
space(4. ENGINEERING STOREROOM' 'A'). 
(5 
(6 


space 
space 


space(5. PERSONNEL OFFICE’? Q`). 
6, ADMIN OFFICE’,’Q’). 


space 


sourcefile(mainfire,|1,1,1,1|.sceneequipready ,ex). 
sourcefile(mainfire,|1,1,1,2 .deenergize.ex). 
sourcefile(mainfire, 1,1,1,3;.fireboundaries.ex). 
sourcefile(mainfire, 1,1,2,1 .approachfire,ex). 
sourcefile(mainfire, 1,1,2.2;.extinguishfire.tp). 
sourcefile(mainfire,/1,1.2.3l.setreflashwatch.tp). 
sourcefile(mainfire,|1,1,2,4|.verifyfireout,ex). 
sourcefile(mainfire,[1,2,1,1|.explosivegastest,ex). 
sourcefile(mainfire, 1. 2,1,2|.desmoke.ex). 
sourcefile(mainfire,/1.2,2,2/.testoxvgentester.tp). 
sourcefile(mainfire,/1,2,2,3) firstoxvgentest,tp). 
sourcefile(mainfire, i 2,2,4/,secondoxvgentest,tp). 
sourcefile(mainfire,[1,2,3,1|.determineamountwater,tp). 
sourcefile(mainfire,|1,2,3,2|.dewater,tp). 
sourcefile(mainfire, 1,2,4,2). BA ex). 
sourcefile(mainfire,|1,2,5,1|.debrief,tp). 

sourcefile( mainfire,|[1,2,5,3],securereflashwatch,ex). 


start(mainfire,|0.0.0.0  ). 
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File Name: equipmentops 


MODE OF OPERATION: 
INDIVIDUAL EQUIPMENT OPERATIONS AND 
BASIC DAMAGE CONTROL ACTIONS 


Author: LT Steve Weingart, USN 


execute _tp(equipmentops, ee =- user directions _ equip _ OPS. 
bagof( TP nodeNo,TPdesc|.node _action(TPnodeNo, TPdesc,tp).TestProc), 
mapsecond( TestProc.Test DescMenu), length(TestDescMenu,Len), 
write no list(TestDescMenu,l.Len). choose tps(Choice), 
tp _test(Choice, TestProc), goodby. 


user directions equip ops:- user(Name), clear. 
write(’ * * * Equipment Operation Tests * * * >°) 
nl.nl.nl. write(Name). 
writelist(0, *, you will be shown a list of equipment related operations’, 
‘and asked to enter which operations you want to review and be tested’, 
‘on. A running score of your performance on your chosen equipment ’, 


‘operations will be displayed. -- GOOD LUCK! ’|), continue. 


3 


choose tps(Choice):- blank lines(2), user(Name). write(Name), 
writelist(0. ', 7, INDICATE WHICH OPERATIONS USING FORMAT "[#.4)."". 
le Sd 1), read(Choice). 


tp_test(Choice, Test Proc):- member(Operation.Choice), 
tp_test1(TestProc.Operation). fail. 
tp test( . ). 


tp testl(TestProc.Operation):- 


~select(TestProc.Operation.TestItem). first(TestItem,TPNo), 
tp file type(TPNo.TPname, ), consult(TPname), execute(TPname,tp), !. 
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File Name: dcactions 


MODE OF OPERATION: : 
INDIVIDUAL COMPLEX DAMAGE CONTROL ACTIONS | 


Author: LT Steve Weingart, USN i 


execute tp(dcactions,tp):- asserta(random yes no(_,no)),assert dummy menu _ items, | 
user directions dcactions.no files(NoFiles). | 
bagof(!TPnodeNo.TPdesc|,node action(TPnodeNo,TPdesc.ex),Tests), | 
delete same(NoFiles,Tests. .,TestProc), 
mapsecond( Test Proc, Test DescMenu), length(Test DescMenu.Len), 
write no list(TestDescMenu.l.Len), choose ex(Choice), 
ex test(Choice, TestProc), goodbv. 


user directions dcactions:- user(Name), clear. 
write(' t** DAMAGE CONTROL ACTMON TESTS T = 
nl, nl, nl, write( Name). 
writelist(O, *, you will be shown a list of damage control related actions”, 
‘and asked to enter which actions you want to review and be tested . 
‘on. A running score of your performance on your chosen damage control ’, 


‘actions will be displayed. -- GOOD LUCK! ”|), continue. 


choose ex(Choice):- blank lines(2), user(Name), write(Name), 
writelist(0,[”, INDICATE WHICH ACTIONS USING FORMAT "[%.4).", 
"le. /1,3,41.7/), read(Choice). 


ex test(Choice, TestProc):- member Action.Choice), 
select( Test Proc. Action. Testltem). first(Testltem, TPNo). 
ex file(TPNo.TPname). consult(TPname).node action(TPNo.TaskDesc, ), 
task instruction(TaskDesc). 
asserta(last report(TPname.Task Desc)), 
execute( TPname.ex).abolish(task score.4). abolish(overall score,3). 
nl, writelist(0, THIS COMPLETES YOUR TEST OF THE DAMAGE CONTROL ACTION”). 


nl, writelist(0, Task Desc), continue. fail. 


ex test(_, ). 


task instruction(Task Desc):- user(Name), clear, 
write? *** DAMAGE CONTROL ACTION TEST * * *5, nl.nl. 
nl, write(Name), writelist(0,'°, you may now direct the actions to ”, 
‘properly execute the action: °|), nl, writelist(0,Task Desc). 
Ia 
writelist(0,|” Your score for this task will be displayed as you carry ’, 


‘out the actions. -- GOOD LUCK!’!), continue. 
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assert dummy menu items:- consult(mainfire). abolish(initiate task.1). 
asserta(handlecasualty _code(0)). correct action oe, : 0.0.0 .mainfire). 


asserta(location(mainfirePERSONNEL OFFICE'.'Q'.'2"."89"."03*)). 


no _files(|: MI a2 1 1.1.1, ],111,1.2 
(1.2.8 11.23). Jif. aA Mel ey 25; alls 


lez al 


jajal 


ex file(! 2',injuredperson). 
ex_file(¡3..brokenequip). 

ex file(/1,1,2.1,1 .openspacebound). 

ex file([2,2.2; .medicalaid). 

ex file((1.1,1.3.3 .closephvsicalopening). 
ex file((1.1.1.1.1.1j,getbattledress). 
ex file((1.1,1.1.1,2;.getoba). 

ex file({1,1.1.1.1.3},getfireequip). 
ex file((1.1,1.1,1.3,1;,putonhelmet). 
ex file((1,1.1,1.1.3,2 .determinerequip). 
ex file((1,1.1,1,2.1).locatefire). 
ex file(/2,2).careforinjurv). 

ex file(/1.1.1,1;.sceneequipreadv). 

Só Ihe 2 .deenergize). 

ex file('1,1.1,3|.fireboundaries). 

ex file(/1,1.2. L), approachfire). 

ex file('1,1.2.4,.verifyfireout). 

ex file('1.2.1.1.explosivegastest). 

' ex file(l1.2.1. 2i .desmoke). 

ex file(,1.2,4.2 .storeequip). 

ex file( 1.2.5.3 .securereflashwatch). 

ex file( 1.1.1.1.1 .getdressed). 

ex file('1.1,1.1.2,.gettoscene). 

ex file( 1.1.1.1.3' .takecharge). 

ex file( 1.1.1.1.3.3 .relieveseniorperson). 
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File Name: prevtraining 


MODE OF OPERATION: 
PREVIOUS FIRE CASUALTY OPERATION TRAINING 


Author: LT Steve Weingart, USN 


execute tp(prevtraining,tp):- user directions prev _training,standby, 
consult (dcactions), clear, 
old_performance(TrainTasks). 
member(Task,TrainTasks). - 
train(Task.TrainTasks.Task Desc). nl. 
writelist(0,'THIS COMPLETES YOUR TEST OF THE DAMAGE CONTROL ACTION”). 
nl, writelist(0.TaskDesc). 
continue.abolish(overall score,3).abolish(task score.4),fail. 
execute tp(prevtraining,tp). 


train(Task.TrainTasks.Task Desc):- first(Task,Task Name), 
describe task(TaskName.Task Desc), asserta(last_report(_,TaskDesc)). 
nl, (node action(TPNo.TaskDesc,NodeType):true). 
((atom(TaskName), assign(TaskName.NTaskName)); 
((NodeType=tp.tp file type(TPNo,NTaskName, )); 
(ex file(TPNo.NTaskName)))). 
consult(NTaskNamej), clear, 
user(Name),nl, write(Name), 
writelist(0, °, vour task will be: 'l), 
writelist(0.TaskDesc), nl, percent(Task.Percent), 
pr list on linef 
'Mour previous performance grade was ,Percent. for this task.')). 
!, execute(NTaskName.NodeType), abolish(last report,2), 


' 


user directions prev training:- user( Name), clear. 
write(' ** PREVIOUS TRAINING REV TOW = same 
nl. nl, write(Name). 
writelist(O, *. you will be retested on the tasks which vou were `^. 
‘just tested on. I’’ve taken the liberty of ordering the tasks’. 
‘with your best first. then your worst second. then your second , 
"best third, then your second worst fourth and so on. `. 
'l think vou''ll enjov this order of retraining the best. 


GOOD LUCK! ”)), continue. !. 


percent(, , , ,Percent|.Percent). $ 
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